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آلہےل۔ اإول 
مكونات الأوراكل 


ORACLE ARCHITECTURE 


ORACLE SERVER 


هو نظام لادارة قواعد البيانات و يتكون من مكونيين اساسيين هما : 


ORACLE INSTANCE, ORACLE DATABASE 


: ORACLE INSTANCE 


من أهم مكونات الأوراكل يحتوي عڵآJ Memory Structure‏ و .Process structure‏ لتتمکن من 
الوصول الى البيانات "ه)و٥"‏ يجب أن يكون ال مء«هء.1 في وضعية العمل» أي انه يتم من خلاله 
الحصول على البيانات المطلوبةء ولا يستطيع ال مءره)وم!] فتح و تشغيل أكثر من مءوطه)ه( واحد فقط 
في نفس الوقت» ولكن من الممكن لأكثر من ٥ء‏ واو.! العمل على ذات ال مووطه٤0a.‏ 


INSTANCE 


Memory Structure 
SGA 


Background Processes Structure 


رسم 1.1 


: ORACLE DATABASE 


عبارة عن مجموعة من الملفات لحفظ البيانات واستعادتها عند الطلب وينقسم الى قسمين هما اهعأوما 
Physical structure sy structure‏ . 


اما ال 1وءاعه] يتكون من أقسام لتخزين وادارة ال مsوجطه)ه0‏ . 
اما ال 1وءإورط۴ يتكون من الملفات الحقيقية الموجودة على الكمبيوتر أو السريفر . 


متال: 


عندما تشاهد صورة على موقع انترنت فإنك تشاهد الجزء ال 1وءاعم] أما الملف الحقيقي للصورة والذي 
مخزن في السيرفر يكون الجزء ال اوور ط٣.‏ يكون هنالك ارتباط بين الجزئين بحيث اذا حذف أحدهما يجب 
حذف الجزء الأخرء اذ لا فائدة من إبقاء ملف الصورة ال 1دء زور ط۴ في السیرفر اذا كنت لا تريد عرض 
الصورة على الأنترنت. 


ویتکون ctu‏ ں)ء sia1رام Database‏ من ثلاث ملفات هي : 


ئ 1هntهع:‏ ملفات التحكم تحتوي على المعلومات اللازمة للمحافظة على ال مووطه)ه0 ويجب ان 
يتوفر على الأقل ملف واحد !يعمل .Oracle Database‏ 

۴6 هD4t:‏ الملفات التي يتم تخزين المعلومات والبيانات داخلها. 

6 ع0ا :8e40‏ تقوم بتسجيل جميع المتغيرات التي طرأت على ال مووطه)ه0 مثل أضافة أو حذف 
بعض البيانات "ه04" لنتمكن من استعادة البيانات في حدوث ضياع بيانات بشكل مفاجئ (مثلاً: انقطاع 
التيار الكهربائي قبل حفظ البيانات المتغيرة). 


ویوجد ملفات أخرى في ال 1دءذورطم ولكنها ليست ضمن ال ase‏ ط Data‏ انما ضمja .Oracle Server ÛJI‏ 
ويجب أن تتواجد لتشغيل واستخدام واغلاق ال مووطه)ه0 مثل: 


.۴ |۷] الذي یحتوی على المعلومات اللازمة للدخول الی ال مہ ه)ءہ] مثل ومعم‎ :Pهssword‎ File 


:Archived Redo Log files‏ عبارة عن نسخ ل ی٥۴11‏ و10 8٥40‏ للمزيد من الأمان في حالة حدوث 
أي ضياع للبيانات. 


Mءصم+ر تخزن المواصفات الخاضة لل مم و٤ءم! مثلا حجم الذاكرة الممنوحة لل‎ :Parameter File 
ومواصفات آخری نتطرق لھا لاحفا.‎ Structure 


ORACLE SERVER PHYSICAL STRUCTURE 


ORACLE DATABASE 


CONTROL FILES 
PARAMETER FILE 
REDO LOG FILES 
PASSWORD FILE 
DATA FILES 
ARCHIVED LOG FILES 


أما ال Structure‏ اogicaا‏ یتکون من: 

"ab espac5‏ : تنقسم ال 45e‏ طهtهD‏ الی وحدات اصغر تسمی ال 26s‏ م٥1ط۲4.‏ کل 4)46( یجب 
ان يتكون من واحد أو أكثر ۲ ومء1ط4٠.‏ يوفر الأوراكل ءءدمء٥1ا14‏ ١٠٠ءر؟‏ في بداية تكوين ال 
Pte‏ کحد ادني ضروري لعمل ال eیئوطه)ه(.‏ 

:Segments‏ ينقسم ال ce‏ 2م1esط‏ ۲4 الی وحدات أصغر تسمی ال 4۶ر" عم؟. 

.E×)eہ٤ ینقسم ال ٤٥د عەS الی وحدات اصغر تسمی ال‎ :Extent 


TO 


:B10 e»‏ تنقسم ال E×)٥۸٤‏ الى وحدات أصغر تسمى ال ءء810 وهي أصغر وحدات تخزين و قراءة 
البيانات. 


سوف يتم التطرق لاحقاً بالتفاصيل في الكتاب لمكونات ال S0 ı1e‏ [c4أو0[.‏ 


DATABASE LOGICAL STRUCTURE 


DATABASE 


TABLESPACE 
SEGMENTS 


EXTENTS 


BLOCKS 


رسم 1.3 


ORACLE MEMORY STRUCTURE 


يتكون من منطقتين تعرفان باسم : 


:System Global Area (SGA)‏ وهي Memory structure Û‏ الخاص بال ce‏ رھtیہا‏ الذي تم 

التحدث عنه مسبقاً (راجع الرسم 1.1) والتي هي أحد أهم مكونات ال مء )وم1 وتحجز المساحة الخاصة لها 
من الذاكرة (أو تبدأً بالعمل) عند تشغيل ال مء هاء.[. وهي ذاكرة مشتركة بین الأوامر "۴٣۵٥٤۲٤٤٥"‏ التي 
تأتي لل مد ھtیہ]‏ مثل وی۴06 5Q1 Query‏ وايضاً مشتركة بين مستخدمي ال موو ط4٤5‏ 
المختلفين»› وتعرف ايض ڊسم : .Shared Global Area‏ 


Glob Area (PGA)‏ r0gramاP:‏ وهي المساحة المخصصة من الذاکرة ل ۴٣٤٣۶‏ ٣هل‏ وتحتوي 
على معلومات حول ال ۴۲۵٤68‏ ۲۷۵۲م؟. وهي ذاكرة خاصة لأمر ''وومع "۴٥‏ واحد فقط, 
وتعرف ايضÎ‏ ڊlصم‏ : Process Global Area 4i Private Global Area‏ . 


„Server Process y User Process J سوف يتم التطرق اح‎ 


Oracle Memory Strcuture 


رسم 1.4 


SYSTEM GLOBAL AREA (SGA) 


جميع مستخدمي ال مء4طه)ه( يتشاركون البيانات الموجودة في هذه المنطقة حيث يتم تخزين البيانات 
المشتركة من مختلف الأوامر "ءعءءء١٠إ۴‏ مءدطه)4(" لكي تسهل عملية استخراج البيانات . يقوم ال 
ماءها0 بحجز المساحة المخصصة له من الذاكرة عند بداية تشغيل ال مء« هه[ ويقوم بتحرير المساحة 
عند انهاء عمل ال مر و٤ء"1ء‏ وتقسم الى عدة أقسام منها أقسام اساسية ضرورية ومنها أقسام اختيارية. 


الرسم رقم 1.5 يوضح الأقسام الاساسية والأقسام الاختيارية (الأقسام الاختيارية باللون الاحمر)» وسوف يتم 
التطرق الى كل قسم على حده. 


SHARED POOL 
AREA 


OTHER MEMORY 
STUCTURES 


رسم 1.5 


تعتبر ال 96۸ ذاكرة مرنة دايناميكية أي ان باستطاعة أقسامها ان تكبر أو تصغر في الحجم دون أغلاق ال 
مnstancا‏ لأسباب مختلفة مثل كثرة العمل ( كثرة الأوامر) على أحد أقسامها اذ أن زيادة العمل على احد 
الأقسام يتتطلب ذاكرة اضافية ولكن لا يمكن للذاكرة العامة لل 56۸4 ان تتخطى الحد الأعلى المحدد بالعامل 
.SGA_MAX SIZE "Parameter"‏ 


ملاحظة:S178_×‏ 86۸_۷1۸ هي احد مکونات اÛ nti اization Parameter File‏ التي سوف یتم 
التطرق لها لاحقاً. 


تذکر: ال ۴1٥‏ مامص ه٣‏ ه۴ التي جاء ذكرها قبل قلیل. 

مثال تطبيقي 1.1: 

لمعرفة حجم ال 564 الحالي اكتب التالي في برنامج 8ا1۲ :5SQ‏ 
SHOW SGA;‏ 


ال System Global Area‏ |7014 تمثل حجم ال S6۸‏ الحالي. 


مثال: 


اذا كانت الذاكرة المخصصة لل 564 حوالي 100 ميغا بايت والتي تعتبر "S6۸_۷۸×_ S17۴"‏ وكان 
التوزيع المبدني للذاكرة على الأقسام المختلفة على النحو التالي: 
=Shared Pool Area‏ 50 میغا بایت 
=Database Buffer Cache‏ 25 میغا بایت 
-R ed0 Log Buffer‏ 10 ميغا بايت (منطقة ثابتة غير متغيرة) 
باقي الأقسام = 15 ميغا بايت. (الأقسام المتغيرة) 
الذاكرة الكاملة = 100 ميغا بايت 


وزاد ضغط العمل علی $4۲٥4 ۲٠۵1 ۸۲٥4‏ بحيث أن 50 میغا بايت لم تعد تكفي» فبمقدور S4۲٥4‏ 
4 ۴01 بان تأخذ ذاكرة اضافية من باقي الأقسام ولكن لا يمكن للذاكرة الكاملة بأن تزيد عن 100 ميغا 


بایت. 
باي 


=Shared Pool Area‏ 60 میغا بایت 

=Database Buffer Cache‏ 20 میغا بایت 

Buffer‏ ع0ا 10-R ed0‏ ميغا بايت (منطقة ثابتة غير متغيرة) 
باقي الأقسام = 10 ميغا بايت (الأقسام المتغيرة) 

الذاكرة الكاملة = 100 ميغا بايت 


الذاكرة في ال $6۸ عبارة عن وحدات متواضلة تسمی sءءاںuرھاG‏ وحجم ال eاuروإی‏ يعتمد على 
.SGA_MAX_SIZE‏ 


SE‏ _ )56۸_۷1۸ أصغر من 128 میغا بایت, اذا حجم کل eاںم‏ هی يساوي 4 میغا بایت آما اذا کان 
حجم ال S17۴‏ )56۸_۷1۸ اکبر من 128 میغا بایت اذارحجم کل eاںu‏ "ه6۲ يساوي 16 میغا بایت. 


الحد الأدني من عدد ال وماuم‏ واي لل 56۸ هو ثلاث. 
واحد مام واي للمنطقة الثابتة في Redo Log Buffer Jû SGA‏ 
y|>ذ Shared Pool Area Û Granule‏ 


Database Buffer Cache Û Granule ذ>|y‎ 


ملاحظة: يمكن الحصول عن بيانات عن .VSBUFFER_POOLje Granules ÛJI‏ 
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:SHARED POOL AREA 


تستخدم لحفظ أخر أو أحدث أوامر ال SQ‏ و ۴1/5S@1‏ وأخر البيانات(المعلومات) المستخرجة من ال 
.Data Dictionary‏ تتكون من قسمين .Data Dictionary Cache s Library Caclıe : lak‏ 


DATABASE BUFFER SHARED POOL 
CACHE AREA 


LIBRARY CACHE 
FOR 
REDO LOG BUFFER SQAL-PLUSAL 


GA CGHEFOR DATA 
DICTIONARY 
LARGE POOL INFORMATION 


OTHER MEMORY 
E STUCTURES 


ربنم 1.6 


باعتبارها منطقة مهمه جداً فمن الممكن تغير حجمها دايثاميكياً (بدون اغلاق ال مءره٤وم1)‏ بحيث لا 
يتجاوزالزيادة فى المساحة مساحة ال 964 المحددہ بالعامJ .SGA_MAX SIZE "Paraıîeter'”‏ 
يعتبر حجم ال SHARED POOL AREA‏ محددة من قبل الخال "ء)e "Para‏ 

SHARED_POOL_ SIZE 

مثال تطبيقي1.2: 

لمعرفة الحجم الحالي ل ۴٠١1 ۸٣٠a‏ ل١إوط؟‏ اكتب التالي: 

SHOW PARAMETER SHARED POOL SIZE; 

في الكمبيوتر الخاص بي الحجم هو : 46 18 و يظهر كالتالي = 46137344 

لتغيير مساحة ال ۴٠01 ۸۲٥‏ 4١١إ4ط؟‏ دايناميكياً اكتب التالي: 

ALTER SYSTEM SET SHARED POOL _SIZE= 64M; 

في حالة نجاح الأمر يظهر الجواب التالي مù .System alfered: SQL PLUS‏ 


أما في حالة عدم وجود ذاكرة أضافية لان تضاف ل ۴٣١1 ۸۲٥۸‏ 4٥4۲طS؟‏ يظھر الجواب 
التlئي .Insufficient memory 1o grow.‏ 
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:Library Cache 
: تحتوي على‎ 


SQL Shared Statements :1 المنطقة رھم‎ - 
PL/SQL Procedures or Packages: 2 المنطقة رقم‎ - 
مثال:‎ 

عندما يقوم مستخدم لل مهه( بطلب جملة ال 5Q1‏ فإن الجملة وطريقة انجاز مهامها تخزن في 
المنطقة رقم 1 وبذلك يسهل عملية تكرار انجاز ٤٥"‏ uءء×٤"‏ ال 5Q1‏ من الذاكرة بسرعة أكبر في حال تم 
طلب نفس الجملة من مستخدم أخر ويذلك تكون العملية أسرع وتخفف العبئ على ما يعرف باسم 
›€0m patios‏ وكذلك ینطبق الحال على .۴1/8Q1‏ 


خطوات عملية: 


الخطوة 1: يقوم المستخدم الأول بطلب جملة ال 9Q‏ التالية : ;وممر0اemp select * from‏ 

الخطوة 2 : يقوم ال كومءهإ۴ إم۷إم$ بدراسة الجملة ومعرفة المراحل التي سوف يتم بعدها 

انجاز "م uءم×>5"‏ الجملة على اعتبار أن هذه الجملة ليست مخزنة في ال مد٣‏ ر٣4إطاا.‏ 

الخطوة 3: يتم تخزين الجملة ومراحل انجالها في ط4٣‏ ر٣4إطاا.‏ 

الخطوة 4: يتم اظهار البيانات الناتجةرهن”جملةال 9Q1‏ للمستخدم الأول وبذلك تكون جملة ال SQ‏ تم 
انجازها وتم تسجيل جميع المراحل التي زت بها" الجملة في ال ط4٣‏ رإ4إطا. 

الخطوة 5: يقوم المستخدم الثاني بعد قليل بگثابة نفس جملة ال SQ1‏ وهي select * from employees;‏ 
الخطوة 6: يقوم ال ۴٣٠٤٤65‏ ٣۷م‏ بدراسةرالجملة فيجد انها موجوده في ال eط4c)٣‏ yاھ۲ط1]‏ فینفذ 
مراحل انجاز الجملة دون دراسة الجملة باعتبار ان المراجل التي تمت لانجاز الجملة مخزنة في ذاكرة ال 
.Library Cache‏ 

الخطوة 7: يتم اظهار البيانات المطلوبة للمستخدم الثاني بسرعة أكبز. 


:Data Dictionary Cache 


Data Dictionary Û ja والتي يحتوي على بيانات‎ SHګARED‎ POO] A۸ R٤4۸ المكون الثاني ٺل‎ 
. Library €2 che وهي تعمل بنفس طریقۂ ال‎ . ables, 1ndexes, Privileges, ec... حول:‎ 


وعندما تمتلئٰ منطفَة rary Cae‏ ط1 أو Data Dictionary Cache‏ یقوم الأوراکل باخراج أقدم 
بيانات لم يتم تكرار طلبها لتعوض ببيانات جديدة وتعرف الطريق بlسصم: Least Recently Used (LRÛ)‏ 
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:DATABASE BUFFER CACHE 


يتم تخزين فيها أحدث البيانات التى تم استخراجها من الملفات الفيزيائية "ء٥۴1‏ و٤54"‏ » وفي حالة طلب 
ذات البيانات من ذات المستخدم أو من مستخدمين أخريين لل مsوطهه‏ يتم استخراج البيانات من الذاكرة 
ولیس من ۴1٥۶‏ 04)4. 


.Least Recently Used (LRÛ) pIظنب ملاحظة: تتم ادارتھا ايضاً‎ 


مثال: 
عندما يقوم مستخدم لل مءوطه)هD‏ بطلب بيانات محددة من ال مووطه)0 عن طريق مثلاً جملة ال اSQ؟‏ 
فإن البيانات المستخرجة من ال وم۴1 و٤4(‏ تخزن في ال Database Buffer Cae‏ وبذلك یسھل 
عملية استخراج البيانات وبسرعة أكبر في حال تم طلب نفس الجملة من ذات المستخدم أو مستخدم أخر وبذلك 
يخف العبئ على ما يعرف باصم .Input/Output Load‏ 


راجع الرسم 1.7 لمزيد من التوضيح. 
الخطوات المبينة على الرسم 1.7: 


الخطوة 1: يقوم المستخدم الأول بطلبج يانات ”من المووطو)ة0 . 

الخطوة 2: یقوم ال ٤٤٥۲م 6٥٣۷٥۲‏ بدراسڈة الطلب ویحضر ال ۴٣٣٤٤۶۶‏ ٣م‏ ۷م البیانات من 
الواذ۴ )4( على اعتبار أن هذه البيانات"القطلوبة ليست مخزنة في .Database Buffer Cache J|‏ 
الخطوة 3: یتم احضار البیانات من ال یم۴1 و4 وتخزن البیانات في .Database Buffer Cache‏ 
الخطوة 4: يتم اظهار البيانات المطلوبة للمستخدم الأول. 

الخطوة 5: يقوم مستخدم أخر بعد قليل بطلب ذات البياناك من ال مووطو)ة0. 

الخطوة 6: يقوم ال مم ٤ء1‏ بدراسة الطلب فيجد ان البيانات المطلوبة تم استخراجها قبل قليل من ال 
ئ taه ‏ ومازالت مخزنة في ال ae Buffer €ac†e‏ ظوDat‏ فیستخرج البيانات من ذاكرة ال 
Database Buffer Cache‏ دون الحاجة الى استخراج البیاناتمن القرص الطلب حيث توجد ملفات 
6 هtه0/‏ ومن ثم يتم اظهار البيانات للمستخدم الثاي بسرعة أكب وجهد أقل. 


وتتكون ال Database Buffer Cache‏ من ثلاثة أجزاء مستقلة تسمى :Sub C€ache‏ 


)اه ط: يخزن في هذا القسم البيانات التي ليست من ضمن الأقسام الأخرى (ءاءرءءR‏ ,م٠)).‏ ويتحكم 
بمساتlq .DB_CACHE SIZE "Parameter'"" Jalil‏ 


م٥٥‏ [: تحافظ على البيانات المخزنة ولا تستبدل» ويتحكم بمساحتها العامل "إم)مa1إ۶Pa"‏ 
.DB_KEEP CACHE SIZE‏ 


:Recycle‏ يتم ازالة البيانات من هذه المنطقة عند عدم الحاجة اليها مجدداًء ويتحكم بمساحتها العامل 
.DB_RECYCLE_CACHE_ SIZE "Parameter"‏ 


ملاحظة: مساحة ال )اده لا يمكن أن تكون ان تساوي صفر أبداً. 
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DATABASE BUFFER SHARED POOL 
CACHE AREA 


LIBRARY CACHE 
FOR 
SQOL-PLUSQL 


DATA DICTIONARY. 


CACHE FOR DATA 
DICTIONARY 
LARGE POOL INFORMATION 
OTHER MEMORY 


HARD DISK 
DATA FILES 


رسم 1.7 


مثال تطبيقي 1.3: 


لمعرفة أحجام أقسام ال Database Buffer °4 che‏ اکتب التالي: 
SHOW PARAMETER DB_CACHE SIZE;‏ 


لتغيير مساحة ال Database Buffer ٤a ce‏ داینامیکیاً اکتب التالي: 


ALTER SYSTEM SET DB_CACHE _SIZE= 30 M; 


:Data Block and Data Buffer 
البيانات المخزنة في ملفات الأوراكل تكون مخزنة نة بشكل كتل ولذلك يطلق عليها اسم وockاB أما البیانات‎ 


المخزنة في ال Database Buffer Cache‏ فتعرف باسم .0ata Buffer‏ وحجم ال Buffer‏ هو نفسه 
حجم م81 والمحدد ڊdlعlمJ .DB_ BLOCK SIZE "Parameter"‏ 


:Data Buffer Advisory Parameter (DB CACHE ADVICE) 


يساعد مدير البيانات (08۸) على ادارةال Database Buffer Cac‏ وخاصة في أوقات الذروة حيث 
يقوم باظهار احصائیات ومعلومات عن مختlلفةJly Database buffer cache‏ . 

يمكن الحصول على البيانات التي ينتجها الئعامd .VŞSDB_CACHE ADVICE je "Para metef"‏ 
وله ثلاث حالات هي: 

:OFF‏ لا يوجد مساحة في الذاكرة مخصصة له وبالتالي لا تقوم بتكوين آي بیانات 

:0N‏ یقوم بتکوین البيانات وله مساحة مخصصة في الذاكرة. 

:READY‏ يوجد مساحة في الذاكرة مخصصة له ولكنه في وضعية الاستعداد ولا يقوم بتكوين اي بيانات. 
ربما تتسائل لماذا اذاً توجد الحالة ۸۷ ۸R‏ لماذا لم بتم الاكتفاء بأول حالتيين فقط؟ 

الجواب على ذلك يكمن في ان انتقال العامل "۲ءء ۲4و۴" من وضعية ال 0۴۳۴ الى 0١‏ قد يؤدي الى 
أخطاء في الذاكرة أو فشل عملية التحويل. 

مثال تطبيقي 1.4: 


لمعرفة الوضع الحالي اكتب التالي: 
SHOW PARAMETER DB CACHE ADVICE;‏ 


: داینامیکیاً بکتابة‎ DB_CACHE_ADVICE "Para mee" يمكن تغيير وضيعة العامل‎ 
ALTER SYSTEM SET DB_CACHE_ ADVICE = READY; 


ملاحظة: قد تفشل المحاولة اذا كان الوضع الابتدائي 0۴۴. 
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:REDO LOG BUFFER 
من أهم اسس حماية البيانات اذ تحتوي على بيانات عن جميع المتغيرات التي طرأت على ال مووطه)ه0 مثل‎ 
.INSERT,DELETE,ALTER,DROP, CREATE التغيرات الناتج4 عن ومر‎ 


المتغيرات التي حدثت في ال مووط هاو تسجل في .Redo Entries pwlڊ Redo Log Buffer J|‏ 
مساح Redo og Buffer J|‏ محددة من قبل اlرامJ .LOG_BUFFER "Paraeter"‏ 


مثال تطبيقي 1.5: 


لمعرفة الحجم الحالي اكتب التالي: 
SHOW PARAMETER LOG_BUFFER;‏ 


لا يمكن تغيير وضيعة العامل 10G_BUFFER "Para 1)٥۲"‏ داینامیکیا. 


تذکر: ان Buf]‏ و0 Red0‏ منطقة ثابتة غير متغيرة. 
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:LARGE POOL 


هي منطقة ذاكرة اختيارية وليست اساسية (اجبارية) يمكن لل 084 ان يقوم بتشكيلها حين الحاجة اليها حيث 
توفر ذاكرة كبيرة لعمليات عديدة .BACKUP and RESTORE Jû‏ 


ملاحظات: 

1- علمية ال 8۸4٤0)‏ هي العملية التي يقوم فيها ال 084 بحفظ نسخ "زمه" من البيانات غالبا 
على أقراص صلبة ءال 11۲١‏ لكي يتمكن من المحافظة على البيانات واسترجاعھا RESTORE‏ عند 
الحاجة. 

2- ال Large P٥01‏ لا تعمل بنظام ال U‏ _. 

3 مساحة ال ۴001 معو[ محددة من قبل عامل .LARGE_POOL_ SIZE "Parameter"‏ 


4- يمكن تغير المساحة دايناميكاً باستخدام A1 ٤R S¥S1 ٤M‏ كما عو الحال مع Shared Pool J|‏ 
وغیرها. 


5- تعمل ال ۴001 مع ۲ھ[ فقط في بیئة .Shared Server J|‏ 


سوف يتم التطرق لاح „Shared Server J‏ 


:JAVA POOL 
أو‎ 8Q1 هي منطقة ذاكرة اختيارية اخرى توفر ذاكرة لعمليات ال 4روا المختلفة وتعمل بنفس فكرة ال‎ 


اP/Q1‏ في ال ۴001 aredطS»ء‏ مساحة ال [ava ۴٠01‏ متحكمة من قبل العامل 
.JAVA_POOL_SIZE "Parameter"‏ 
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CONNECTION 


لكي تستطيع الدخول الى ال مءوطهه للقيام بعلميات مختلفة مثل استخراج بيانات عبر جمل ال 8Q1‏ › 
يجب أولاً ان يكون المستخدم متصلاً بال م وا؟ہ1. 

يقوم المستخدم باستخدام أحد البرامج التي يمكن عبرها الاتصال بال 4#٤ء"!‏ مثل 501۲S‏ فينشئ ما 
یعرف باسم ۴۲٥٤6٤۶‏ ۲عءNآ.‏ وبعد ان یتم الدخول الی ال إم۷امS‏ م[ء إ0 ویتم الاتصال بال Insta ce‏ 
ینشئ ما یعرف باسم ۴۲٥٤6۶۶‏ ام۷ مS.‏ یقوم ال ۴٣٥٤٤5‏ rم۷امS‏ بعملیة الوسیط بین المستخدم میا 
P0s‏ وال معnstan]‏ حيث يقوم بتنفيذ العمليات التي طلبها المستخدم متثل جمل ال اSQ.‏ 


connection 


Database User ORACLE SERYER 
1.8 رسم‎ 


:Process 


تعريف ال ۴۲٠٤٠١١‏ بشكل عام في الأوراكل هي العملية أو الوظيفة التي تنفذ مجموعة من الخطوات أو 
مهمات محددة. 


يوجد ثلاث أنواع من ال sعءوم‏ ه۴۲ في الأورIکJ‏ ھم: User Process , Server Process,‏ 
.Background Process‏ 


. Background Process J aح¥ سوف يتم التطرق‎ 


:Session 


ال رهوومS‏ هو حالة الاتصال الموجودة بين المستخدم و ال إم۷مS‏ ماءوإ0. يبدأ ال رمزوومS‏ عند دخول 
المستخدم ال Se‏ ما0 وینتهي عند خروج المستخدم من ال S٥۷‏ ٥[cھإ0‏ سواء بإرادة 
المستخدم (عند انتهاء المهمة) أو لا ارادياً (عند حدوث عطل ما). 

يمكن للمستخدم الواحد اين يكوّن أكثر من «هإووم؟ واحد في نفس الوقت اذا استخدم أكثر من برنامج مثل 
SQL PLUS‏ و ORACLE FORMS‏ عدا بعض الحالات القليلة. 
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:PROCESSING A STATEMENT (DML) 
ملخصة في الخطوات التالية:‎ (M1 (جمل ال‎ SQ الخطوات التي تمر عبرها جمل ال‎ 
.Server Process sg User Process jùjıyكتy‎ Instance Jlب يتم الاتصال‎ 


اذا كانت البيانات المطلوبة غير متوفرة في Database Buffer Cache J|‏ يم Server J|‏ 
Pr cs‏ باحضار البیانات من ۴٥۶‏ 4)4 0. 


يقوم ال ۴٥٤6s‏ rمrvمS‏ بوضع قیود ")0" على البيانات التي یتم تعدیلهاء ویتم تخزين 
البيانات السابقة (قبل التعديل) في منطقة ROLLBACK (SEGMENT) BLOCK Jm‏ 
حتى يستطيع المستخدم باسترجاع البيانات الأصلية غير المعدلة اذا تم اختيار ءوط[1هR‏ عوضاً 
zEۍù .Commit‏ 


. اذا تم اختيار ٤انصإه) فإن البيانات المعدلة يتم نقلها الى وم[¡۴ و)0‎ ٠ 
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PROGRAM GLOBAL AREA (PGA) 


هي منطقة ذاكرة غير مشتركة و خاصة لعملية واحدة فقط "ع٥۲۵‏ ". تخصص ذاکرة ال P6۸‏ لكل 
عملية ۴۲٣٤۲٣٤۶"‏ " عند بداية العملية ۴٣٠٤٥"‏ " و تزال ذاكرة ال ۴6۸ عند نهاية العملية 
"ءا " . وتحتوي ذاکرة ال P6۸‏ على البيانات الخاصة لتلك العملیة ۰'۴٣٥ ٤٥"‏ مکونات ال ۴6۸ 
تعتمد على تعریف ال إع۷مS؟‏ حیث يوجد تعریفان .Shareds Dedicated lak‏ 

في نظام ال Dedic4)e4 Server‏ یتکون Server ۴٣٥٤٤۶‏ واحد خاص لطلبات ۴٥٤٤١۶‏ ٣م‏ ءل واحد 
(مستخدم واحد)» أما في ال م ۷مS‏ ۵٥۲هط؟‏ فیتم المشاركة في ال $٥۷٥٣ ۴٣٣٤٤5‏ من قبل آكثر من 
ser Process‏ (یمکن ان يكون هناك آکثر من ۲۲۵٣٤۲٤٤6۶‏ ۲٥۷م‏ و ليس بالضرورة واحد فقط أي مثلاً 
یمکن ان یوجد خمسة وموو ع٤٥٣۴‏ ۷۲٣م‏ یتشارك بھم خمسین مستخدم sمء‏ ع٥0٣۴‏ مs€)‏ 


:۴6G۸ بعض مکونات ال‎ 
يحتوي على الأوامر التالية:‎ ۴٣٠٤٤55 حیث تخصص لأي طلب من قبل ال‎ :S0 R1 AREA 
Union, Minus, Ja Set Operators JI Î Distinct , Order By, Group By, 


.Intersect 


:SE10N [NF ORMATION *‏ حیث تخصص لمعلومات المستخدم مثل ال rمeیل‏ 
.Privileges‏ 
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BACKGROUND PROCESSES 


تکون ال Ba ckع ٥u” ۴۲٥٤٤565‏ متوفرة وجاھزة للعمل بعد تشغیل ال ce‏ وtیہ].‏ 
کل Background P065‏ مسؤول عن مهمات خاصة» ویوجد نوعیین من dہu٥اع8ack‏ 
۴‰ هما آختیاری و إلزامي ( او إجباري). 


تذكر: الرسم رقم 1.1 ومكان وجود .Background Pإ0cesses JI‏ 


Database Writer (DBWn) 
Log Writer (LGWR) 
System Monitor (SMON) 
Process Monitor (PMON) 
Checkpoint (CKPT) 
Archiver (ARCn) 
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:DATABASE WRITER (DBWn) 


يقوم بكتابة البيانات الnتغيرة Data ÛI gl Database Buffer Cache JI ja "Dirty Buffers"‏ 
۴ كما هو موضح بالرسم 1.9 وبذلك يتم تفرغة ومfں8‏ باستمرار من أجل البيانات المتغيرة اللاحقة. 


0 


تذكر: أن البيانات المخزنة في ال ceہھtیہ]‏ تسمی ]ں8 والبيانات المخزنة في ال و٥۴‏ 4)4( تسمی 
.Blocks‏ 


وتعمل ال ر (8W‏ عند حدوث أحد الأحداث التالية: 


عند حودù .Checkpoint‏ 
عدد ال Dirty Buffers‏ (أو ال Buffs‏ الممتلئة بالبيانات المتغيرة) يصل الى الحد الأعلى 
المسموح فيه. 


عند عدم وجود من "۹ عگں8 "۴٥١‏ فارغة بعد البحث عنھا من قبل ال ۲٣٣٤٤65۶‏ . 

عند وضع ءءدمءء1[ط 14 سواء من النوع العادي أو المؤقت في حالة الإغلاق "ءدنا؟؟0f".‏ 
عند وضع ٥ءدمءع1ط‏ ه٣‏ في حالة القراءة فقط (اي لا يمكن تغيير البيانات بل فقط الاطلاع 
."Read Only" (lle‏ 

عند وضع ء4ومء٥1طه‏ في حال .Backup Û‏ 

عند استخدام أوامر D۲٥‏ و c4٥‏ ں۲۲ الخاصة بال 1۲ 1۵. 

.۲ "٥0 u٤ عند حدوث‎ 


. Tablespacè.di sC eckpoi1 Û سوف يتم التطرق ¥حقً‎ 


DATABASE 


: Control Redo Log 


oir] [Lowe] [oe] 


1 
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:LOG WRITER (LGWR) 


0 


يقوم بنقل البيانات المخزنة في ال Log Buffer Cae‏ الى ال Redo 0g ۴¡1es‏ بشكل دوري مما 
يساعد على اخلاء ذاكرة لل یز٤٤‏ 0ء8 الجديدة » كما هو موضح بالرسم 1.10. 


تذكر: أن البيانات المخزنة في .Redo Entries awî Redo Log Buffer Û|‏ 
وتعمل ال ۷R‏ 1,6 عند حدوث أحد الأحداث التالية: 


.Redo Log Buffer J| عند امتلاء ثل‎ 

عند وجود بيانات في ال R ed0 10g Buffer‏ حجمها اکبر من M8‏ 1. 
قبل ان تقوم ال D(8 Wp‏ بنقل البيانات من Data Files ÛI gli Database Buffer Cache JI‏ . 
کل 3 ٿوان. 

.Transaction Commit iz 


DATABASE 


Data Files Control Redo Log 
Files 
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:SYSTEM MONITOR (SMON) 


في حالة حدوث اي عطل مفاجئ لل مء روود[ جميع البيانات الموجودة في ال #م )٤وہ‏ (مثل بيانات ال 
(Database Buffer Cache‏ التي لم یتم نقلھا الی ال ی۴1۲ و)5a‏ على القرص الصلب تضيع أو تمسح. 
بعد هذه الحالة من ضياع بيانات ال مم ووم يعمل ال ۸ 0 S9۷]‏ بشكل اتوماتيكي لاسترجاع بیانات ال 
Instance‏ و تسın‏ Ûlعlة‏ پ .Instance Recovery‏ 


ويقوم ال 5910١‏ بتأدية عدد من الوظائف هي: 


٠ه‏ استرجاع البيانات المتغيرة التي تم تسجيل ما طراً عليها من تغیر في ال ۴1٥s‏ ع10 8e٥‏ ولکن لم 
یتم تسجیلها في ال و۴16 و٤04.‏ حیث قوم ال ×90 بقراءة ال 6sا¡۴ 8R ed0 10g‏ و معرفة 
التغيرات التي طرأت على البيانات و تغيير البيانات في ال 6ذ۴ و٤0a.‏ 

. اعادة تجهيز ال مءوطه)ه ليتمكن المستخدم من الدخول مجدداً‎ ٠ 

٠‏ الغاء جميع ال ورمذاووم وآ التي لم يحدث لها انمه وازالة القيود عن البيانات " وج5 
"Lock‏ . 

.Da)a ۴ ¡[es واستعادة مساحتها الی ال‎ remporary Seg me ٤s تحریر ال‎ ٠ 

ه جمع المساحات الخالية الصغيرة الضائعة التي تنشىئ بين البيانات نتيجة للتغيرات التي تحدث و 
تعيدها الى المساحة الخالية الرئيسية. 


تذکر: أن ال 16۷۴ یعمل قبل ال W۷‏ 58. 


سوف يتم التطرق لاحقا في الفصول الال لل Temp0r2y Segê]‏ . 


:PROCESS MONITOR (PMON) 


في حالة حدوث أي عطل لل وعءء ۴٠٣٥‏ قد يؤدي الى مشاكللداخلية في ال مط هه( فیقوم ال PMO‏ 
بتنظیف أخطاء ال .۴٣٥٤ 6٤56s‏ 


ويقوم ال P10١‏ بتأدية عدد من الوظائف هي: 
تحریر کل المصادر وال وم1 علی ال وم1 ط ه۲ أو ال 8٥s‏ التي وضعها ال P٣٥۲ ٤۶۶‏ الفاشل. 


اعادة (ackط11اRo)‏ ال ansactionا"‏ الخاص بالمستخدم (اي الغاء اي تعديلات لم يتم حدوث 
(lj Commit‏ 
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:CHECKPOINT (CKPT) 


ال Cheek poin٤‏ هي عملية كتابة جميع البيانات المتغيرة في مطءو٣C Data Û ll Database Buffer‏ 
۴s‏ عبر ال و .D8 W‏ من فوائد ال ٤«ذهم‌اعمطC‏ ان البيانات التي تتغیر باستمرار تنقل بشكل نظامي و 
دوري الی ال و٥۴1‏ و٤4(‏ وبذلك يتم حفظ البيانات بشكل أمن. 

.Control Files JI y Data Files Header JI "Update" ڊتجديد‎ pg Checkpoint Process Û 


: من البيانات التي تجدد ")ولم لا"‎ 
.Data Files Header JI „ê Checkpoint J| رم‎ e 
.Control Files JI „ê Checkpoint ÛJI رم‎ e 
.Control Files Û ي‎ Log Sequence J| رم‎ 
.Control Files JI aê SCN Jl 
„Archived Log J| slawl e 
SCN Jig Log Sequence JI s Data Files Header Ji سوف يتم التطرق لاحقا في الفصول التالة‎ 
«Archived Log J ءlaسly‎ 


:ARCHIVER (ARCn) 

هو P۲٥۲٤۶‏ اختیاری و لیس اجباري وواظیفتهاتکمن في نقل بیانات ال Archived Jl Redo Log Files‏ 
.1٥‏ باعتباره اختياري فله حالتيين "مثا يعمل أو مغلق. و لوضعه في وضيعة الل يجب ان يکون ال 
tabe‏ في وضعية ال ٤06G‏ 1۷ ۸)8 وفي حال تم وضع ال مءaطه)a‏ تحت هذه الوضعية فإن 


RC‏ يعمل. 
اذاً هناك حالتيين لوضعية ال مووطه٤ه‏ 5 تحددان عمل أو ایقاف ال م٣۸۸‏ هما: 


:Archivelog 


عند امتلاء الملف الأول من ملفات ال Redo Log Files‏ ڍpî‏ البداً قي كتابة البيانات في الملف الثاني وتسمی 
هذه العملية ٠ Log Switch‏ ثم یقوم ال و٣ ۸R‏ بشکل أوتوماتيكي نقل بيانات الملف الأول الى ال 
.Archived Log Files‏ 


DATABASE a 
Data fle 1 File 1 o Log : 
e ا‎ Archived 
a = : 
Data rile2 | File 2 Redo Log Log Files 
E Redo Log 
Data File 3 File 3 


رسم 1.11 


:_NoArchivelog 


عند امتلاء جمیع ملفات ال ۴|1٥۶‏ ع10 40ء8 يتم اعادة كتابة البيانات "ء٤ذس‏ ٣م0۷"‏ في الملف الأول 
على البيانات السابقة » ولكن لا يتم كتابة البيانات فوق البيانات السابقة قبل ان يحدث ٤مذمم‏ )عمط للملف 
أو مجموعة الملفات الممتلئة. 


سوف يتم التطرق لاحقاً لكيفية وضع ال ع2 ط وا04 تحت حال .Noarchivelog J> si Archivelog JI‏ 
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الفہےل الثاب 
تنصيب و إدارة الأوراكل 


INSTALLING & MANAGING 
ORACLE 


DATABASE ADMINISTRATION TOOLS 


: يتوفر عدد من الأدوات "ء01٠1" في الاوراكل أهمها‎ 
ORACLE UNIVERSAL INSTALLER (OUT) ° 
ORACLE DATABASE CONFIGURATION ASSISTANT ° 
SQL PLUS 
ORACLE ENTERPRISE MANAGER (OEM) ° 


PASSWORD FILE UTILITY ° 


:ORACLE UNIVERSAL INSTALLER (OUI) 


یمکن استخدام ال 011 لتنصیب "6۵11وږ1""الاوراکل. في نظام الویندوز "۷,۵٥۷"‏ تستطیع بدا ال 
1 بالضغط على ملف التنصیب ال ×e‏ م ںام؟ › اما في نظام ال ×زہ ل فیجب کتابۂ .٣۸]٦۶)2[[e۲‏ 


4 
الرسم 2.1 يوضح ال 1ا0 في نظام الويندوز»"؟س نلم¡ ". 


Y@ oracle Universal Installer: File Locations 


File Locations 


Source... 


Enter the full path ofthe file representing the products) you want to install: 
Path: | Eistageiproducts.jar 


Destination... 
Cioracleiorad2 


ORACLE 


الرسم 2.1 
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من أهم ممیزات ال 071: 

٠‏ يمكن تنصيب الأوراكل اكثر من مرة على ذات موقع التخزین مثل الو¡ 4۲4 باستخدام اسم 
مخلتف ٺل  RACLE HOME‏ الموضح في رسم 2.1 (أسفل کلمة ٥0٤ھ"‏ ذtوءە0)‏ و یمکن 
تنصيب نسخة قديمة "«٠إوء۷‏ 014" للاوراكل مع نسخة جديدة "0و۷ سم" في ذات 
الموقع. 

٠‏ يمكن تنصيب الأوراكل من الإنترنت عبر وصلة ال H۲7۶‏ حيث تواجد نسخة الأوراكل» وبذلك يمكن 
تنصيب الأوراكل من قبل فرع شركة في دولة غير الدولة التي يوجد بها مقرها الأصلي (حيث تتواجد 
نسخة الأوراكل). 

ه يمكن أن يستعمل لإزالة الأوراكل من الجهاز أو السيرفر (Uninstall or D¢eins†a1[(‏ 

o‏ يعمل بعدد مختلف من اللغات مثل الانجليزي و الفرنسي و الألماني و غيرها. 

ه يمكن ان يعمل تحت الأنظمة التي لا توفر نظام ال G1‏ والتي تكون فيها الأوامر بشكل كتابي 
mmandص€‏ ولیس كما في ال وس ٥م۷1‏ الذي يعمل تحت نظام ال 611 مثل الرسم 2.1. 


وتسمى الطريقة باسم الطريقة الصامتة M0٠"‏ ٤۸ء[1؟"‏ ويتم استعمال ملف يسمى مكرResp0‏ 
.File‏ 


:Response File 


هو ملف (any name.txt)‏ يحفظ البيانات اللأؤمة لعملية التنصيب مثل البيانات المطلوبة في الرسم 2.1 
( مثل بیانات ال Source‏ و .(Destination Û‏ 


:ORACLE DATABASE CONFIGURATION ASSISTANT 
:)2.2 يستخدم للأغراض التالية (انظر الرسم‎ 

ه تكوين البيانات "مء4ط0a)a'.‏ 

ه حذف البيانات "مءaوطDa)a".‏ 

٠ه‏ تعديل خواص البيانات "مءوطه)و5"'. 


.Templates J| ار‎ e 


سوف يتم التطرق لاحقا في فصل أخر لجميع الأغراض. 
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Ê : Oracle Database Configuration Assistant, Step 1 of 9: Operations ا ادا‎ 


Select the operation you want to perform 
ê Create a database 
CC Configure database options in a database 
C Delete a database 


` Manage Templates 


cancel | Help j 


رسم 2.2 


:SQL PLUS 

هي اداة تمكن المستخدم من التفاعل مع البياناتء حيث تمكنالمستخدام من الدخول الى البيانات» استخراج 
بيانات» اضافة بيانات» تعديل بيانات» واغلاق البيانات "مءوطو٤4(".‏ من المفروض أن تكون قد عملت مع 
ال 5Q1 PS‏ خلال دراستك لل 8Q1‏ وتعرفت علیھ جیدا. 


# Oracle SQL*Plus 


File Edit Search Options Help 


SQL#PIus: Release 9.8.1.0.1 - Production on Fri Dec 13 8080:00:41 2802 
(c) Copyright 2881 Oracle Corporation. A11 rights reserved. 

Enter password: xxxxx#* 

Connected to: 

Oracle9i Enterprise Edition Release 9.8.1.1.1 - Production 

with the Partitioning option 


JServer Release 9.80.1.1.1 - Production 


SQL> | 


رسم 2.3 
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:ORACLE ENTERPRISE MANAGER (OEM) 


هو نظام أداري يعمل على التحكم بمكونات الأوراكل وادارة البيانات من خلال نظام ال 01 6(اي يتم القيام 
بمعظم الأوامر من خلال استعمال الفارة .)"١ use"‏ 


من اهم مکونات ال ٤M‏ 0: 
CONSOLE‏ 


ORACLE MANAGEMENT SERVER ° 
MANAGED NODES ° 


MANAGED 
NODES 


REPOSITORY 


aoe | 


E ee 
CONSOLE E3 


:Console 
1ا6" من الأدوات الهامة حيث تعمل كمحطة لإدارة جميع المهمات في آوراكل. من هنا يمكن‎ ٠٠۵١١" أداة‎ 


التحكم بالمء مهو[ ويمكن التحكم بال وم[اطه] و غيرها و تنفيذ المهمات عن طريق الفأرة '"useم١"‏ 
والإختيارات المتعددة عوضاً عن تنفيذ المهمات بواسطة جمل ال اS@Q.‏ 
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Oracle [nterprtse Manager Console Standalone 


File Navigator Qbject Tools Gonfiguraton Help ORACLE 


EnberprSeAaNARE 


Gj Network 
CG Oataases 
bg DBNAME - SYSTEM AS S 


Use Instance Management to 


€ Sthema 
aoc » Start up and shut down a database 
Storage » View and edit the values of instance 
وز‎ ation re 
» Manage users' §eSSions, and view 
4 ou currently running SOL and ts explain 
3m plan 
DUê Workspace » Manage in-doubt transactions 
» Monitor long-running operations 
» Cûntrûl processing rêSûurcês via 
Resource Plans 
» Manage stored configurations 
» Administer IockS arid SeSSions 
consuming the highest amounts of 
resources (if the Diagnostics Pack i5 


installed) To learn more about Instance 


click tte Quick Tour bı 


ISS [BISE sa2 & e0 


رسم 2.5 


من الملاحظ من الرسم 2.4 أن ال ء1مء, ه٤‏ رشتطيع الدخول الى إم۷إ٥S‏ 1ء0۲ بطريقتيين هما: 
oneاStanda:‏ بطريقة مباشرة دون الحاجة Management Serve)‏ eاOrac.‏ (سھم رقم 2) 
عبر ال M18‏ 0: عبر .Oracle Management Server ÛJI‏ (أسھم رقم 1) 


DBA Tools 
:Cهرو0إ[ءe هي مجموعة من البرامج التي يمكن تشغيلها من ال‎ 


."0و٤aط4ءء" يستخدم لتشغيل واغلاق ومراقبة البيانات‎ :اnstance‎ Manager 
.Privileges s Users Accounts دژر‎ piy :Security Manager 

:Storage Manager‏ يستخدم للتحكم في ال وموم 1ط ۲4 وال ۴16s‏ و٤04‏ وغیرها. 
Manager‏ aصem‌Sch:‏ یستخدم لتکوین وادارة ال ۲416s‏ و س۷1 وال s¢×eل"1.‏ 
:SQ1 PLUS Worksheet‏ اداة لكتابة جمل ال 5Q1‏ وتنفیذها. 


:Oracle Management Server (OMS) 


أھم مکونات ال Enterprise Manager‏ eاOrac‏ یقوم بدور الوسیط بین ال ۳C0 ns01¢‏ و Managed Û‏ 
Ns‏ في تبادل البيانات بالاضافة الى ادارة وأرuهءء۸‏ إءءل وعمليات مختلفة مثّل و) مم۷٤‏ ,sط0ل.‏ 
یقوم باستعمال ال راه)‌زوهمه8 لتخزين بيانات النظام "د)٥‏ ”٠ءءر؟"‏ وبيانات البرامج والأدوات و 
بیانات .Managed Nodes Û‏ 
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:Managed Nodes 
ما یعرف‎ ×0٥ من ال مط( وخدمات أخری. یوجد علی کل‎ N0 قد تتکون ال‎ 
يقوم بالتواصل مع 0[18 ويؤدي المهام المرسلة من قبل ال‎ 0اacاe‎ 1ntelligent Agen باسم‎ 


۴ي )› وهو يعمل بشکل منفرد ویمکن ان يؤدي مهام مثل اغلاق و تشغیل ال مط ه٤(‏ ویلزم 
Oracle ntelligent Agent‏ واحد فقط علی کل 4e‏ 0×. 


:PASSWORD FILE UTILITY 

تعرف باسم لس مه0 وتستخدم في تکوین ال .P4%W 0۲ ۴1e‏ 

لتکوین ال ٥ذ۴‏ لام سووه۴ يجب اتباع القاعدة التالية: 

Ş$ŞORAPWD FILE = filename PASSWORD = yourpassword ENTRIES=number; 
هي كلمة السر الخاصة ب‎ ٣ویءw‎ od حیث ان ال ۴1۲ هو اسم الملف وموقعه على الجھاز› وال‎ 
تمل العدد الأقصى من المستخدميين الذين يحق لهم الدخول‎ Entries وال‎ .SYSOPER و‎ SYSDBA 
.SYSOPER,j|SXSD 84A iı الى ال #sوطDatab في‎ 


عندما تقوم بالدخول كمستخدم ال 84 23¥S5فانك‏ تدخل الى و ءطءS S۷8‏ ولیس ال 4٤1ء5‏ الخاص 
بك وكذلك عند الدخول کمستخدم ال ۲ER‏ 9¥50 فانك تدخل .PUBLIC Schema JÛ‏ 


تذکر: ملف ال ۴1٥‏ 0۲۵ سه۴ من الفصل الأول. 
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AUTHENTICATION METHODS 


للقيام بالمهمات الإدارية للبيانات "ءء4طه٤4("‏ يقوم الأوراكل بتكوين اثنين وامںهءء۸ ۲ءء عند بداية 
تكوين البيانات "eء4ط‏ 044" هما S۷8‏ و ال 9۷S۲ E۷‏ الذین یملکان جمیع ال eعم‏ ۴۷11 في 
الاوراکل أو ما یسمی ال ¢[اR0 .D8۸‏ 


ملاحظة: كلمة السر لل S۷5‏ عند بداية تكوين البيانات هي ااو٤ورذ_«ر0_ءع«هطء‏ اما كلمة السر لل 
.manager aê SYSTEM‏ 


.Database Data Dictionary Û "Owner" dllمnll هو‎ S¥S ملاحظة2: يعتبر ال‎ 


هناك طريقتتين يمكن السماح فيها للمستخدمين الذين يملكون ال ء۸1 8۸( الدخول الى ال #ووطو)4( 
وادارة اlبيlنlٽ‏ ھla: .Operating System Authentications Password File Authentication‏ 


:PASSWORD FILE AUTHENTICATION 


لقد تطرفنا قبل قلیل لل را1٤‏ ا ء۴1 6۲۵ سه۴ والتي تستخدم في هذا النظام› ولتشغیل هذا النظام یجب 
اتباع الخطوات التالية: 


1- تکوین ملف ال Password ۴11e‏ عن طریق:ال .٥⁄0۸۸ ° WD‏ 


2- وضع BMOPÊ_LOGIN_PASSWORDFILE JI‏ "۸ الذي هو أحد مکونات ال 
.EXCLUSIVE éذlaÛ| gûl Initialization Parameter File‏ 


3- اعطاء "٤ر "Gra‏ ال Privileges‏ الخاص ب S¥95(84۸‏ أو 9۷90۴8۸ الى المستخدمين 
الجدد الذين تم اختارهم للحصول ال ۲ا۸0 08۸. 
مثال تطبيقي 2.1: 
الخطوة 1: اكتب التالي في ال Sا۲۴1‏ اSQ؟‏ 
Ş$ORAPWD FILE=c:\loracle home\ora92\dbs\myfile PASSWORD=newadmin‏ 


ENTRIES=5; 


:2 الخطوة‎ 
SHOW PARAMETER REMOTE _ LOGIN _PASSWORDFILE; 


اذا كانت الحالة غير E٣10 S1۷٤‏ فيجب تغيير الحالة في .Initialization Parameter File JI‏ 


:3 الخطوة‎ 
GRANT SYSDBA TO Ahmad; 


للدخول الى ال مووط هه اكتب التالي: 
CONNECT sys/newadmin AS SYSDBA;‏ 
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:OPERATING SYSTEM AUTHENTICATION 


بمجرد الدخول الى ال إعاكر؟ ع«ناوإءم0 (مثال: الويندوز) تستطيع الدخول الى ال #ءووطه)0a‏ دون 
الحاجة الى كلمة سر أو اسم مستخدم. 


ملاحظة: يجب أن يكو REMOTE_LOGIN_PASSWORDFI1LE ÛJI‏ في حالة NONE‏ ليعمل 
النظام, 

مثال تطبيقي 2.2: 

بعد الدخول الى ال 801۲18 اكتب التالي: 


CONNECT / AS SYSDBA; 


حlلIٽ :Remote Login Passwordfile JI‏ 
يوجد ثلاثة حالات يمكن وضع ال 1e¡؟01 Remote ogi ٣_۴24‏ فيها هي: 
EXCL [۷E ٠‏ : تحدد ان ce‏ آرھ)5ہ] واحد فقط یمکن ان یستخدم ال ۴w 0۲۵ ۴1٥‏ ویمکن 
|eطlء SYSDBAYPrivileges JI "Grant"‏ و YSOPER Privileges ÛJI‏ لمستخدمین 
أخرين» وهي ضرورية لنظام اÛ .Password File Authehtiéa tion‏ 
:SHARED *‏ تحدد ان باستطاعۂ آکثر من ce‏ ہھ٤وو]‏ استخدام ال ٥ا۴ ٥۲۵‏ swءھP‏ ولکن لا یمکن 


اضافة مستخدمين أخريين لل 9۷5084 أو ٤R‏ $90۲ والمستخدم الوحيد المعرف في الملف 
هو .S¥S‏ 


.Operating System Authentication مl¡زil‎ aرaرض¦‎ :NONE ° 
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OPTIMAL FLEXIBLE ARCHITECTURE 


یعتبر ال 0۴۸ نظام لترتيب و توزيع ملفات ال #aطه)ه(‏ المختلفة على حسب نوعها أو استخدامهاء وهو 
معتمد في جميع الآنظمة التي يعمل بها الأوراكل مثل .Windows, U N1×‏ 
باستخدام نظام ال 0۴۸ يمكن ان نحقق عدة فوائد منها سهولة التمييز بين الملفات المختلفة وسهولة ايجادها 
وسهولة ادارة الأوراكل بتوزيع الملفات كل حسب نوعه»ء وتسهيل التحكم في التوسع الذي يطرأ على ال 
t6‏ في المستقبل. 
و باستخدام نظام ال 0۴۸ نستطیع: 

ه اعتماد اسلوب ثابت لتسمية الملفات لكي نستطيع ايجاد الملفات بسهولة. 

.Oracle Database ùe Oracle Software J| تافأlم تفريق‎ 

ه تفريق ملفات النسخ المختلفة "د 0ذوء۷" من الأوراكل. 


تفریق ملفات ال مان و٤5‏ عن ملفات ال Contro1 Files‏ عن ملفات .Redo Log Files JI‏ 


ا×اھاے 8 

| Fle Edt View Favorkes Tools Help le 
| desk - > - GJ| Qseuh Folders Hatay | ê Û X | E- 
2 ك‎ 


Modfied: 9/16/2003 6:37 PM 
Attributes: (normal) 


ا 
I‏ @‘ ®‘ 
0 
3 
3 }[ 
3 


DO :0 e 
3 
3 
i 


dasses 
EF 
doc 
jdbc 
Mshelp 
oledb 


ocommon ODBC oem_webst olp 
ا‎ 
oracore oradata ORAINST ord otrace plsql 
اګ‎ 
Lobject(s) selected ooo]  Imconrke 
2.6 رسم‎ 


كما تلاحظ توزيع ملفات ال مsطههD‏ المختلفة الى مجلدات مختلفة. فمثلاً تجد ملف ال ۴assw 0۲ ۴1e‏ 
تحت مجلد ال وا1 بالمقابل تجد ملفات ال ۴6s‏ 1٥إ٤ہره)‏ تحت مجلد ۲4ہ وھکذا... 
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INITIALIZATION PARAMETER FILE 


لتشغیل ال ٥٥ہ‏ ھtیہ!‏ یجب توفر ال .[nitia ization Parameter File‏ یمکن استعمال أکثر من ملف 
لنفس ال مءوطه)04. هنالك نوعان مj Initialization Parameter File Û‏ ھما: 


initSID.0r4 يطلق عليه اسم الملف الثابت "ء۴1 ic)۾)S" ويعرف باسم‎ :P۴]LE 
spfileSID.ora pصlڊ‎ فرeڍs‎ "Persistent File" موlقnll يطلق عليه اسم الملف‎ :SPFILE 
ہ ھ٤وہ[. فاذا کان اسم ال ceہوt٤یم] "8ط(' فیکون اسم‎ ce عبارة عن رمز لإسم ال‎ S1 ملاحظة: ال‎ 
.(initDb8B.ora) املف‎ 
:Initialization Parameter File J| بعض محتوياٽ‎ 
.SGA_MAX_SIZE Û! مثل‎ SGA Ûاs‎ Instance Jlب الخاصة‎ "۴a4 ۸٥)" العوامل‎ 
.!ہیtھ‎ ce اسم ال مووطه)ه« التي يعمل عليه ال‎ 
.€Cم٤٣٥1‎ ۴ [e4 اسماء و مواقع ال‎ 


‘Undo Segment J| بیانات عن‎ 
.Noatchielég siArchivelog la! دıدحت‎ 


INSTANCE 


:PEILE 


Initialization 
Parameter File 


user 


رسم 2.7 


هو ملف من نوعية ال 1> الذي يمكن فتحه وتغييره بواسطة ال كدم٠٤ه٠N‏ وغيرها من برامج الكتابة. 
يتم قراءة محتوياته عند بداية تشغيل ال مء ه)ء"1 ومعظم العوامل "١٥٤م‏ ۲4و۴" الموجودة داخله لا 
تعمل بشكل دايناميكي ( يستلزم اغلاق وفتح ال ,)و1 من جديد لكي يحدث التغيير) عدا بعض العوامل 
"rameterه"‏ التي يمكن تعدل دايناميكياً في الذاكرة ولکن تظل في ال P۴1۴‏ كما هي (أي انه عند 
تشغيل ال ٥٠‏ )ء1 مرة أخرى يرجع الوضع الى قبل التعديل الدايناميكي). 

يوفر ال 001 ملف مبدني عند بداية تكوین ال مو ط هه اسمه 0۲۸.٤1ہ:‏ يمكن استعماله لتکوین ال 
.PFILE‏ 
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بعض مکونات ال :P ۴11۴٤‏ 


db_block_size=4096 

db_cache_size=33554432 

open_cursors=300 

background _ dump_dest=C:\oracle2\ora92\admin\dbname\bdump 
core_dump_dest=C:\oracle2\ora92\admin\dbname\cdump 
timed statistics=TRUE 
user_dump_dest=C:\oracle2\lora92\admin\dbname\udump 
db_domain=oracle 

remote_login passwordfile=EXCLUSIVE 

control files=("C:\oracle2\ora92\oradata\ldbname\(CONTROLO(01.CTL", 
"C:\oracle2\ora92\oradata\dbname\(CONTROLO02.CTL", 
"C:\oracle2\ora92\oradata\ldbname\CONTROLO03.CTL") 
compatible=9.0.0 

db_name=dbname 

instance_name=dbname 

java_pool_size=33554432 

large pool size=1048576 

shared_ pool size=33554432 

processes=150 

fast_start_mttr target=300 

sort_area_size=524288 

undo_management=A UTO 

undo_tablespace=UNDOTBS 


اعد :PFILE J|‏ 
ه كل العوامل '"ءإم)م_وإه۴" اختياريةء أي اذا لم يحدد ال 84( قيمة العوامل ""ءإم)مص "Paa‏ 
أو لم يتم كتابة العامل "۲۸۲4٥۲‏ في ملف ال P۴11۴‏ يقوم الأوراكل بتحديد العامل 
"rameter"‏ و تكون قيمته هي القيمة المحددة سلفاً من قبل الأوراكل "ںاج۷ )[uوf¢("‏ 
ترتیب العوامل "۲۶ع )ص۲4 ھ۴" في ال P۴1۴٤‏ غیر مهم. 


٠‏ اذا كان هناك أكثر من قيمة للعامل "١۲ع)ع‏ 4٣و۶"‏ الواحد فب فيجب وضع القيم داخل قوسين و 
تفریقهم بفاصلة كما في و٥۴‏ _1٥إ٤۸٥C.‏ 


هه تحدد قيمة العامJ "Paramter'"‏ بهذه الصيغة (العامل ك القيمة). 


ه يمكن استعمال (#) في الملف لوضع ملاحظات داخل الملف (هذه البيانات لل 84( ولا يقرأها 
الأوراكل). 
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:SPEILE 

هو ملف من نوعية ال رهاط الذي يقوم بادارته ال veمS‏ مه0( فتحه و تعدیله) ویمکن تعدیل جمیع 
قيم العوامل "١٣ء4٣۴4"‏ الموجودة داخله بشكل دايناميكي (اي باستخدIم (ALTER SYSTEM JI‏ 
بحیث یتم تعدیل بیانات ال $9۲۴1.۴٤‏ في الذاكرة أو الملف أو الأثنين معا (أي انه عند تشغیل ال e‏ )یہ1 
مرة أخرى تكون التغيرات التي اجریت على ال S۲۳۴11۴٤‏ بواسطة ال ER S¥S1 ٤M‏ ]ا۸ موجودة 
وثابتة). 

لا یقوم الاوراکل بتکوین ملف 5۲۶۴11٤‏ ابتدائي کما یحدث مع ال P۴1۴٤‏ ولکن یتم تکوین ال ۶۲۴1۴٤‏ 
من ال P۴1٤‏ کا سیأتي شرحه بعد قلیل. 

لتعدیل العوامل ٣4,٥٤٥۲۶"‏ ے۴" داخل SP۴1٤‏ يجب اتباع القاعدة التالية: 

ALTER SYSTEM SET PARAMETER = VALUE [SCOPE = SCOPE_VALUE]; 
ملاحظة: استخدام ال [ ] في القواعد يدل على أن هذا الجزء اختياري و في حالة لم يتم كتابته يختار الأوراكل‎ 
ال ٤اه( . وال )هه( يكون أحد الحلات الأكثر شيوعاً وهي تم اختيارها مسبقاً من قبل مبرمجي‎ 
الأوراكل.‎ 

أما حالات ال S)0PE_VA LUE‏ ثلاث رهي: 


:MEMORY °‏ يتم تغيير قيعة'ةاآه۷" ال إءtء٠‏ .4٣و۴‏ فقط في الذاكرة» أي عند تشغيل ال 
مc stan‏ مرة اخری تلغی التغیرات: 


:SPF]LE‏ یتم تغییر قیمة e"‏ ں[ھ ۷ ' اَل )ھ۴ في ملف ال SP۴1€٤‏ فقط 


B0 1H‏ : یتم تغییر قیمة 'eں[ھ‏ ۷" للعامل "6۲٤6ہ‏ ھ۴" في ملف ال S۶۴1٤‏ والذاکرة 
معاً. 


ملاحظة: اذا لم يتم كتابة الجزء C0 PE-=-SCOPE_VA LUE‏ فیعتبر الأوراكل انها 
.(Default Û ga BOTH) SCOPE=BOTH‏ 


:2.3 مثال تطبيقي‎ 
ALTER SYSTEM SET SHARED POOL _SIZE = 33554432 SCOPE=SPFILE; 


بعض مکونات ال P۴1٤‏ 8: 


*. background dump_dest='C:\oracle2\ora92\admin\dbname\bdump' 
*. compatible='9.0.0' *.db_block_size=4096 *.db_cache size=33554432 
*. db_domain='oracle' 
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لیست کل العوامل ٥)٥۲"‏ ۲4 ھ۴" في ال S۶۴1٤‏ اختیاریةء یوجد سبع عوامل "۴۸۲4۸٥٤٥۲۹"‏ یجب 
ان تحدد هي: 


.BACKGROUND_DUMP_DEST 
USER_DUMP_DEST 
DB_NAME 

SHARED _POOL_ SIZE 
COMPATIBLE 
DB_BLOCK_BUFFERS 
CONTROL_FILES 


سوف يتم التطرق لاحقاً للعوامل '"ءرع)ع1ر ۶۸,۸" الجديدة لاحقا, 


Create SPFILE 


یمکن تکوین ال ٤۴۔۴1 SP‏ من ال P۴1٤‏ اذا کان المستخدم يمlك S¥YSDBA ROLE‏ أو 
YS0PER Role‏ باتباع القاعدة التالية: 


CREATE SPFILE [='location and name'] FROM PEILE[='location and name']; 
في القاعدة اذ يمكن للأوراكل تكوين الأسم على النمط‎ $۴1٤ یمکن اهمال ذکر اسم و موقع ملف ال‎ 
المذكور سابقاً (و510.0ء۴11مء) وفي الموقع ال_٤[u ه٥( وهو ضمن المجلد ءط1. كذلك الحال بالنسبة لل‎ 
حيث يختار الأوراكل الملف المعرف بالأسم و م.1810¡ وضمن المجلد وال.‎ P۴1٤ 


ملاحظة: قد يختلف الموقع ال ٤1ء5‏ من نسخة أوراكل الىأخرئا. بعض نسخ الأوراكل تكون الملف ضمن 
المجلد مووطdata.‏ 


مثال تطبيقي 2.4: 


SQL PLUS JI من‎ 
CONNECT / AS SYSDBA; 


CREATE SPFILE FROM PFILE; 
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یمکن تعدیل ال SP ۴1۴٤‏ من ال ۴ا )0NS0‏ باتخاذ الخطوات التالية: 


«Enterprise Manager Console JÛ ادخل‎ 

.St4 "210e اختر الوضع‎ 

اضغط على قائمة ال مءوطوخو0 ثم قائمة "اسم ال #sوDatab"‏ 
يطلب منك الاسم و كلة السر. 

اكتب اسم ال 9۷S۲ ٤EM‏ وكلمة السر الخاص به. 

تأكد من وضع وه ٤م«ده)‏ الى الحالة 8۸4 S5؟¥S.‏ 

اضغط على قائمة ال eمو)یم].‏ 

.Configuration jذlع اضغط‎ 

„All Initialization Para eter JذغE ضط‎ 
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1515 ce Stale 


چ 7 


E‏ 358 ا 
Locks‏ 
lS lir SUE: 115 1552 NE | Cag MES‏ 
lA Fes aur:3a Cor sUrier i‏ 
lA Fesaur:2 F as‏ 
—fAHesour:a F an Sched‏ 
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¥ ciran 
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START UP A DATABASE 


يوجد ثلاث حالات يمكن أن نبدأ تشغيل ال مءوط )ه0 ولكل منها خاصيته والوظائف التي يمكن اجرائها في 
تلك الحالة« الحالات الثالثة بالترتيب : .NOMOUNT , MOUNT , OPEN‏ 
:NOMOUNT‏ 


تسمى عملية ممواومآ مط مذو لأنه في هذه المرحلة فقط يبدأ تشغيل ال مء ه٤ء"[]‏ دون باقي أجزاء 
.Oracle Database Û‏ 


يمكن القيام بوظيفتين في هذه الحالة هماء 


„CREATE DATABASE) SQL JI ةlaج عبر‎ Data تكوين ال 4ط‎ 
.Control Files Û تكوين أواعادة تکوین ملفات‎ 


سوف يتم التطرق لاحقاً لكيفية تكوين ال عءوطواو( باسخدام جمل ال 1ا@5. 
يتم في هذه المرحلة عدة أمور هي: 
٠‏ تتم قراءة ملف ال Parmeter ۴1e‏ iationاnitia]‏ بحیث يبحث الأوراکل على ملف 
SPF1LE‏ إن لم یجد یبحث عن ۴۳۳1۲۴٤‏ وإن لم يجد تتم قراءة الملف وإم.٤نما.‏ 
ه حجز مساحة من الذاكرة لل .S64‏ 
.Background Processes Û Î e‏ 
فتح ملف یسمی وہ[.۲۲915ء1[ه وملفات تسمی "۲۲۸۰۲.۴15 . 
سوف يتم التطرق لاحقا ٺل Trace Files s 4[e1{51D. [og‏ . 


ملاحظة: يجب تحديد قيمة انعامJ B_NAME "Parameter"‏ لكي يعمJ .NOMOUNT Jl‏ 


:MOUNT 

في هذه المرحلة يمكن القيام بوظائف مهمة مثل: 
îخيıر .Data Files JI slaw "Rename"‏ 
٠‏ امكانية وضع ال مووط0a)a‏ تحت وضعي .NOARCHIVELOG yi ARCHIVELO0G JI‏ 
eعملJ‏ صilة .Database J "Recovery"‏ 

يتم في هذه المرحلة عدة أمور هي: 


ه فتح وقراءة ملفات .Control Files Û|‏ 
٠‏ ربط ال مsوطه)ه‏ بال مم واوم!ا الذي سوف يعمل عليها. 
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:OPEN 


هي الحالة العادية التي تم العمل فيها بواسطة ال 50۲1S‏ ويتم اجراء تعديل وحذف واضافة بيانات 
وغيرها من المهام. 


يتم في هذه المرحلة عدة أمور هي: 


. Online Data Files JI تج‎ e 
.Online Redo Log Files JI gid e 


في حالة فشل فتح ملفات ال و٥۴1‏ واد وال ٥ذ۴‏ ٠لءR‏ او في حالة حذفها أو نقلها من مواقعها المحددة 
في ال C٤٥1 ۴1e‏ فلا یمکن ان تعمل الحالة PEN‏ 0. 


lal Initialization Parameter Files JI مخزنة في‎ €٥ م٤01‎ ۴16s ملاحظة: اسماء ومواقع ال‎ 
.C0 ۲01 ۴11e فهي مخزنة في ال‎ Redo 10g F۴ ¡[es وال‎ (4٤a ۴11e اسماء و مواقع ال‎ 


STARTUP Command 

لتشغيل ال seوط4٤a‏ 5 في احدى الحلات-المذكورة سابقاً تستعمل القاعدة التالية: 
STARTUP [FORCE] [RESTRICT] [PFILE='location and name']‏ 
[OPEN [recover] [database’sname] | MOUNT | NOMOUNT ];‏ 


ملاحظة: استخدام ال | في القواعد يدل على انها (أو) "© . فمثلاً لا يمکن MOUNT J‏ و OPEN Û‏ 
ان يتبا معا. 
أوامر القاعدة : 


٤اP۴1:‏ سبق ذكر ان الأوراكل يبحث عن الملف عند بداية مرحلة ال N1‏ ا0 .0M‏ ولكن يمكن للمستخدم 
تحدید ملف محدد عوضاً على ان يقوم الأوراكل بالبحث عنه. 


:RECOVER‏ خاصة فقط بمرحلة ال 0۲8۸ اذ لا یمکن کتابتھا مع ال 100.1 وعند استخدامها 
يقوم الأوراكل بعمل عملية ال ٤R‏ 0۷] ۸ للبيانات. 


"ESR 11‏ : تحدد المستخدمين الذين يحق لهم الدخول الى ال #ووطهtه0‏ وهم من يملك ال 
Restricted Session Privilege‏ التي سوف یتم التطرق لھا لاحقاً. 


:۴0RCE‏ اذا كان ال ما11 يعمل في احد الحالات فيمكن اغلاقه ثم تشغيله مباشرة في الحالة العادية. 
اذا هي مثل عملية ال "١٤ء‏ ®" في الويندوز. 
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مثال تطبيقي 25 
لاستخدام قاعدة ال 0۲ا1 91۸۸ يمكن القيام بالتالي: 
1- ادخل الى ال SQL PLUS‏ أو عبر ڑÛ .Command Prompt‏ 
2- ادخل اسم المستخدم و كلمة السر. 
3- يجب الدخول الى 84 S¥S5‏ عن زرıق CONNECT \ AS S¥SD84۸;‏ 
4- اغلق ال موو طو٤و‏ بواسطة الجملة التlلية: SHUTDOWN;‏ 
;۶ا S1 R‏ في هذہ الجملة یعتبر الأوراکل انھا 0۲٤۸‏ باعتبارھا ال {)[uںوfء50.‏ 


STARTUP MOUNT; 
STARTUP NOMOUNT; 


:ALTER DATABASE Command 
: يمكن ان تستخدم في عدد من الوظائف منها‎ 
: تغيير حالة ال seواaوtوD من‎ -1 


.MOUNT J NOMOUNT ° 
OPEN yil MOUNT ° 


يمکن استخدام أمر ال L۲ ER DATA BASE‏ باتباع القاعدة التالية: 


ALTER DATABASE [database's name] MOUNT | OPEN; 


مثال تطبيقي 2.6: 
بينما يتم استخدام حالة ال N1‏ ا NOM O‏ يمكن التحويل الى ال 71ا0" بكتابة التالي: 


ALTER DATABASE MOUNT; 


2- لوضع ال موو طواهD‏ في حالة القراءة فقط :"Read-Only Database"‏ 


يمكن فتح ال مء ط)4( في حالة 0۴٤۸‏ بدون السماح بتغيير البيانات في ال مء4طه)ه( باستخدام 
القاعدة آلتالية: 


ALTER DATABASE [database's name] OPEN READ WRITE | READ ONLY; 


.Default J| ga READ WRITE jİ lll ع‎ 
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مثال تطبيقي 27 
بينما ال موو ط واد في الحالة العادية "R2۸5 W۷ R1۲۴"‏ يمكن التحويل بكتابة الجملة التالية: 


ALTER DATABASE OPEN READ ONLY; 


من الوظائف التي يمكن القيام بها بينما ال مءوطهtة0‏ في وضعي :READ ONLY J!‏ 
۰ استخراج بیانات عبر جمل ال ا@8. 


.Online s Offline ùıڊ‎ Data Files J| تغيير وضعية‎ ٠ 
.Tablespaces Jly Offline Data Files JI JE Recovery J| ةıلمعب القيام‎ 


:Restricted Mode 


یمکن تشغیل ال می4 طa)4‏ 5 في هذه الحالة لإعطاء المجال للمستخدمين الذي یملکون 
Restricted Session Privilege‏ من القیام بمهات خاصه. 


مثال تطبيقي 2.8: 


لتشغيل ال موو ط)0 في حال Réstricted J|‏ : 
STARTUP RESTRICTED;‏ 
يمكن تحويل الحالة بشكل دايناميكي باستخدام: 


ALTER SYSTEMBENABLE RESTRICTED SESSION; 
ALTER SYSTEMDISABLE RESTRICTED SESSION; 


في بعض الأوقات (وخاصة بعد وضع ال Qع)ء1إ٤ء۸)‏ يريد ال 84 (أو من يملك الصلاحيات) باخراج 
بعض المستخدمين من ال ٥ء4طه)ه‏ للقيام ببعض المهمات. يمكن القيام بهذه المهمة عبر: 


ALTER SYSTEM KILL SESSION 'SID, SERIALF'; 


ال S1‏ هو رقم ال رهذووم؟ الخاص (يعطى لكل «موومS‏ عند بداية تشغيله رقم خاص به) يمكن استخراجه 
ڻمjù .V$SESSION‏ 


ال 1۸1# SER‏ ھو رقم خر ممیز "٥ں‏ 1ں" یعطی لکل «ه‌ووم؟ ویمکن استخراجه من ایضاً من ال 
.VŞ$SESSION‏ 
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مثال تطبيقي 2.9: 
يمكن القيام بعملية "ووم 11" باتخاذ الخطوات التالية: 


ه يجب أن يكون هنالك أكثر من مستخدم يعملون على ال مودطهه( في نفس الوقت» للقيام بذلك 
ادخل الی 7Sڄ 5Q۴‏ اول باسم مستخدم ثم افتح ال 5Q۲ ٥S‏ مرة أخری وادخل باسم 
مستخدم اخر. 

username = SCOTT , password =TIGER pدختwl و‎ SYSTEM oدختسا‎ 


ه يتم كتابة الجملة التالية من ال 7٤۷‏ S؟S۷؟:‏ 


SELECT USERNAME, SID, SERIAL# 
FROM VŞSESSION 
WHERE USERNAME = 'SCOTT!'; 


ه يظهر الناتج التالي (يختلف من جهاز الى أخر) 


USERNAME SID SERIALF# 


SCOTT 9 51 


یکتب مستخدم ال 9۷5۲٤۷‏ التالی: 
ALTER SYSTEM KILL SESSION '9, 51!';‏ 


٠‏ يتم اغلاق ال «هووم؟ الخاص بالمستخدم .5Š٣٥0 ٤١‏ يقوم ال M]0١‏ ۲ بمهامه مباشرة لمعالجة 
الأثار التي يمكن ان تنجم عن أغلاق ال «هiووم$‏ _الخاص بالمستخدم 11 S٤٥00‏ واذا قام 1 S€C0T‏ 
بطلب جملة 5Q1‏ تظهر الرسالة llتlلية: YOUR SESSION HAS BEÈN KILLED‏ 


ا× اقا *oradesaus‏ 


File Edit Search Options Help System user 
2 FROM UŞ$SESSION 


3 YHERE USERNAME = ‘SCOTT'; 


ھ 


USERNAME SID SERIALH 

SCOTT 9 51 

SQL> ALTER SYSTEM KILL SESSION '9,51'; ل‎ 

E 

Ew l4 
ا×اھا۔‎ 
File Edit Search Options Help SCOtt 
SP2-8842: unknown connand "SES" ~- rest of line ignored. ا‎ 


SQL> SELECT * FROM EMPLOYEES ; 
SELECT * FROM EMPLOYEES 


# 
ERROR at line 1: 
ORA-898028: your session has been killed 


SQL> 


27 | اه 
رسم 2.9 


45 


SHUTTING DOWN THE DATABASE 


يمكن اقفال ال موو طوغو0 في اربع حlلات‏ ھa: NORMAL, TRANSACTIONAL,‏ 
.IMMEDIATE, ABORT‏ 


ملاحظة: عادة ما تكون عملية اغلاق ال مووط واه من أجل عملي ال up)ء84.‏ 
ملاحظة2: لإغلاق ال ase‏ ط ata‏ تحتاج | .SYSOPER yİ S¥SD8BA‏ 
لإغلاق ال مووطواه( في احدى الحلات المذكورة تستعمل القاعدة التالية: 
SHUTDOWN [NORMAL] | [TRANSACTIONAL] | [[MMEDIATE] | [ABORT];‏ 


مع العلم أن 1 NORMA‏ هي ال De fه u1‏ أي عند کتابة ال W٩‏ 3110۲00 بدون أي من الحالات 
الأربع يفترض الأوراكل أنها الحالة ال )إuوfء50.‏ 


:NORMAL 
بهذه الحالة يتخ التالي:‎ Database J| في حالة اغلاق‎ 


لا یسمح بدخول مستخدمیین جدد لل:مي4طة)04. 

٠ه‏ لا يغلق ال مءوطهه قبل خروج جميع المبنتخدمين منه» أي ان الأوراكل ينتظر حتى يفرغ 
المستخدميين من مهامهم ثم خروجهم لكي يتم اعلاق_ال مءوطه)04. 

.Redo Eoğ. Files JI ll Redo Log Buffer J| ٽانlيب يتم نقل‎ 

.Data FilesdÛ! yil Database Buffer Cache J| تانlيب يتم نقل‎ 

في حال وجود عملیات لم یتم حدوث .ROLLBACK ll دحيû COMMIT‏ 

.Background Processes J| ناء وجو‎ 

ازالة مساحة ال S64‏ من الذاكرة. 

اغلاق ال مھ ط ٤ھ‏ ثم اغلاق ال .Inst4 nce‏ 


ملاحظة: لا يستلزم ان تتم عملية رم ۷٠ء٠8‏ للبيانات التي كانت موجودة في ال مء و٤و.!]‏ باعتبار انها 
نقلت الى الملفات الفيزيائية. وعملية ال رإءرهءء8R‏ هي العملية المشابهه لوظائف ال۸ ۴M0‏ و SM0×‏ . 


:TRANSACTIONAL 
عدا الإختلافات التالية:‎ NORMAL J| بهذه الحالة یتم جمیع خطوات‎ Database ÛJI في حالة اغلاق‎ 

٠‏ لا يغلق ال مووطهtه‏ قبل انهاء المهمات التي طلبها جميع المستخدمين منه» أي أن الأوراكل ينتظر 
حتى يفرغ المستخدميين من مهامهم التي طلبوها قبل حدوث أمر الاغلاق ولا ينتظر أن يخرج 
المستخدمين من ال مووطوه لتتم عملية الاغلاق كما يحدث في ال .NOR M41‏ 

ه لا يسمح بالقيام بمهمات جديدة من قبل المستخدمين بعد أمر الإغلاق. 

ه يتم اخراج المستخدم من ال مووطه)ه( عند انتهاء المهمات التي طلبت قبل عملية الاغلاق. 


ملاحظة: لا يستلزم ان تتم عملية رمء 0۷ء٠8‏ عند تشغيل ال مع ه)ء"] مرة أخرى. 
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:IMMEDIATE 
عدا الإختلافات التالية:‎ NORMAL Û بهذه الحالة یتم جمیع خطوات‎ Database ÛJI في حالة اغلاق‎ 


ه٠‏ يتم اغلاق ال مط هه( فوراً دون انتظار خروج المستخدمين أو انهاء مهامهم التي طلبوها قبل 
أمر الاغلاق. 

ه المهمات التي تم طلبها قبل أمر الاغلاق تلغى وأية تعديلات طرأت على البيانات بسببها تزال وتمسح 
(بشرط ان تكون المهمة ما تزال تعمل عند أمر الإغلاق( ويحدث .ROLLBACK lq‏ 


ملاحظة: لا يستلزم ان تتم عملية ء۷٠٠٠8‏ عند تشغيل ال #ء« هو" مرة أخرى. 


:ABORT 


في بعض الحلات الخاصة عند عدم استطاعة الأوراكل اغلاق ال مءدطه٤هD‏ بأحد الحلات الثلاث السابقة يتم 
في حالة اغلاق ال موو طه٤ه‏ بهذه الحالة يتم التالي: 


٠ه‏ يتم اغلاق ال مءوط هه( فوراً دون انتظار خروج المستخدمين أو انهاء مهامهم التي طلبوها قبل 
أمر الاغلاق. 

ه المهمات التي تم طلبها قبل أم4الآغلاقتلغى و أية تعديلات طرأت على البيانات بسببها تزال وتمسح 

(بشرط ان تكون المهمة ما تزال تگال ”عند أمر الإغلاق( ولا يحدث .ROLLBACK lq‏ 

.Redo Log Files Û Jl\l Redo Log Buffer J| تانlيب لا يتم نقل‎ 

Data Files JI ll Database Buffer Cache J| تانlيب لا يتم نق‎ 

المهمات التي لم يحدث لھا .ROLLBACK lq ùدكي ¥ COMMIT‏ 

یتم اغلاق ال مط هھ وال "٥‏ هی[ بشکل فوراي. 


ملاحظة: يستلزم ان تتم عملية رإء 8٠٠0٠۷‏ عند تشغيل ال مء ه)كو[ مرة أخرى. 


ملاحظة2: تأثیرات ال ۲R ۴ORO٣٤‏ و عند حدوث أي عظل في ال مء ء1 يؤدي الى اغلاقه 
هي ذات التأثيرات .SHUTDOWN ABORT Jl‏ 
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DIAGNOSTIC FILES 


تعتبر ملفات ال ناومعٍه1( ملفات مهمة لإدارة ال مم و)وم] لأنها تخزن بيانات حول العمليات المختلفة 
التي تجرى على ال مووطه)ه5. يوجد عدد من ملفات ال نوم معه1( منها: 


[ER1 L0G FILE *‏ : يتم تخزين البيانات حول العمليات أو المهام اليومية التي تجرى على ال 
.Database‏ 


Background Jl J> يتم تخزین بیانات‎ : BACKGROUND TRACE FILES 
.Processes 


USER "RACE FILE °‏ : يتم تخزين بيانات حول الأخطاء الفادحة التي يقوم بها المستخدمون 
والتي قد تؤدي الى تعطل ال مووط وو( وبذلك تساعد على اكتشاف الاسباب التي أدت لتعطل ال 
.Database‏ 


:ALERT LOG FILE 


لکل ٥٥ےہ‏ ملف ع0 ۸1٥۲٤۲‏ بحیٹ اذا لّ يقم المستخدم بتکوینھ یقوم الأوراکل خلال بدا ال ce‏ )یم 
بتكوين الملف (خلال مرحلة ال )NNOMNOU NT‏ وهو يعرف باسم .alertSID.1og‏ يعتبر Alert Log JI‏ 
هو المرجع الأول في البحث عن الأخطاء (تشتخيص) التي حدثت في ال موو طهاه( بشكل يومي. 

موقع ال ۴1۲ ۸1٥۲‏ محدد من قبل العامJل‏ "îıéteFضPara" .BACKGROUND_DUMP_ DEST‏ 


تذکر: جاءٍ ذكر lاlعامJ BA €CKGROUNDEDUMP_ DEST "Parameter"‏ في موضوع ال 
.SPFILE‏ 


یتم تخزین البيانات عديدة في ۸1۲٤ 0g ۴٥‏ منھا: 


توقیت بدأ تشغيل ال مء و٤وہ1‏ وتوقيت الاغلاق. 

.Background Processes JI Jیغشت توقیت بدا‎ 

بیانات حول ال طSwi)c‏ 0gا.‏ 

بيانات حول الاخطاء التي زۈهرت ."Error Messages"‏ 

بیانات حول تکوین ال وم 4م٤٥1( .٣۵‏ 

بیانات حول تکوین ال d0 Seg 1٤")‏ ا. 

جمل ال 8Q‏ التي تحتوي على الأمر 1٤8‏ ۸. 

رقم ال 10g Sequence‏ الخاص بال nine Redo 10g ۴ ¡1e‏ الذي يتم العمل عليه من قبل ال 
LGWR‏ 


. Undo Seg nets Jl سوف يتم التطرق ¥حقاً‎ 


تذکر: جاء ذکر ال 10g Sequence Number‏ في الفصل الأول. 
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:BACKGROUND TRACE FILES 

يتم تخزين بيانات حول الاخطاء التي تحدثها ال sمءء‏ ع١٤٠۴۲‏ أ«u٠إع)ءه8.‏ يتم تكوين الملفات فقط عندما 
تحدث الأخطاء (أي انه في حال عدم حدوث اخطاء لا تكون الملفات متواجده). 

موقع الملفات محدد من قبل العامل .BACKGROUND_DUMP_ DEST "Parameter"‏ 


:'USER TRACE FILE 
يتم تخزين بيانات حول الأخطاء الفادحة التي يقوم بها المستخدمون والتي قد تؤدي الى تعطل ال مووطوخة(‎ 
موقع الملف محدد من قبل العامل‎ ."14-٠" التي تم طلب مراقبتها‎ 5Q وبيانات حول ال‎ 
.USER_DUMP_ DEST "Parameter" 
و المحدد ب 10 میغا‎ 1۸× DUMP_FILE_S1IZE "P44٤٣" يتحكم في حجم الملف العامل‎ 
بايت. يمكن تشغيل أو ايقاف الملف في ال «هذووم؟ الواحد او في ال مع و٤ءم! (كل ال و«مذوومS التي‎ 
موجودة في ال مع« وا٤وم1) عبر كتابة التالي:‎ 
:Sمیو10‎ 1 في ال‎ 
ALTER SESSION SET SQL _ TRACE = TRUE; 
:1ہ؟t4‎ ۸e في ال‎ 
:Initialization Parameter File J| ألتالي في‎ "۴4٣4 عمد‎ ٣" او عند وضع قيمة العامل‎ 
SQL _TRA@E = TRUE 
وتسجيل»بيانات(جوالها والأخطاء التي سببتها.‎ 5Q1 جميع جمل ال‎ "1۲1٥٥" وبذلك يتم تعقب‎ 
.SPFILE JI ي موضع‎ USER_DUMP_ DEST "Parameter" Jماalا تذکر: جاء ذکر‎ 
تسمی بالقاعدة‎ 8acekع٥u”4‎ ۲٣٥۲ فمثلاً ملفات ال‎ .))٣٤( بالرمز‎ ۲٣۹٥١ ۴٥و تعرف ملفات ال‎ 
مثل‎ sid? RO٣CESSNA۸ ME. .†c التالية: ( كما الملفات الموجودة في نسخة الأوراكل الخاصة بي)‎ 
هو اسم ال مع »ای1 في جهازي والذي يحدد عند عملية التنصيب).‎ dbname) dbnamePMON. tre 


وكذلك الحال بالنسبة لأملفات User Trace J|‏ في تسمی بالقاعدة التالية في نسخة الأوراكل الخصة بي: 
.ORA00853.trc Jî ORAPID.tre‏ 


ملاحظة: قد تختلف قاعدة التسمية من نسخة آوراکل الى آخری ولکن ال و٥۴1 ۲۲۹٤٤٥‏ تنتهي دائماً ب ).٤٣٥(‏ 
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ORACLE MANAGED FILES (OMF) 


تسهل ال M۴‏ ادارة عدد من ملفات الأوراكل اذ يكفي تحديد مواقع الملفات فيقوم الأوراكل بالاهتمام 
بالملفات و تكوينها وحذفها وتسمیتها. یمکن تحدید مواقع الملفات باستخدام عاملین "۴۸٣4٥٤٥۲۹"‏ اثنین 
جدیدن من عوامل ملف ال Para mءامإ ۴11e‏ izationاntia]‏ اضيفا في النسخة التاسعة من الأوراكل 
"Oracle9i"‏ ھما: 


. Daa ۴6s الذي یحدد مواقع ال‎ :0(8B_CREATE_FILE_DEST 
وال‎ 8R ed0 10g يحدد مواقع ملفات ال‎ : (B8_€CREATE_ONLINE_LOG_DEST n * 
یدل الحرف (۸) على رقم العامل "۲ع٤٥ ۶۲4" بیحث یکون من واحد الى‎ .C0ntro1 Files 

ملاحظة: يمكن استخدام أحدهما أو كلاهما, ولا يشترط استخدام الاثنين معاً. 
ترتبط کل ce‏ ےم٥1ط‏ ۲1 بملف من ملفات ال 0a4 ۴1s‏ ( 1ےcذعہا[-ica1ذووط۴)‏ بحیث یکون لکل 
espaceاab"‏ ارتباط بملفات من ی٥۴11‏ و4(. اي انه عند حذف ال ٥ceےمءم‏ 1طا۲ یجب حذف ملف ال 
هاه المرتبط معها وإلا قد يسبب مشاكل عند عملية ال up‏ )ء4 8) اذ انه لا فائدة من حفظ ال و٤و0]‏ 
۴s‏ باعتبار ال ce‏ 4م٥1‏ ط۲۹ تم حذفها. 
يجب على ال 084 البحث عن الملفةالمرتبطوجذفه بطريقة عادية (كما يتم حذف أي ملف في الويندوز أو 
ال ×1 N‏ ال أو غیرھا). آما اذا تم استخدام طریقة ال M۴‏ یقوم الأوراکل بحذف ال یذ۴ (٤a‏ دون تدخل 
ال D84‏ أي بطريقة أوتوماتيكية وهذه أحد فۇائد استخدام ال .0M۴‏ 


يتم استخدام )٥۲4_(‏ في بداية اسماء ملفات ال M۴‏ 0ل دلالة عليها. 


مثال تطبيقي 2.10: 

DB_CREATE_FILE_ DEST = 'C:\oraclelora92\oradata\uO01'" 
DB_CREAE_ ONLINE _LOG_DEST 1 ='C:\oraclelora92\oradata\u02' 
DB_CREAE_ ONLINE _LOG_DEST 2 ='C:\oraclelora92\oradata\u03' 
.ALTER SYSTEM يمكن تغيير القيم "ءعں 1و۷" بشكل دايناميكي باستخدام‎ 


ALTER SYSTEM SET 
DB_CREATE _FILE_DEST='C:\oracle\lora92\oradata\u04'; 


بعد ان يتم تحديد العوامل ٥)٥١"‏ هد۴" (كما في المثال 2.10) تتم عملية تكوين ال مط هه باستخدام 
مر ..)REA E DATABASE‏ اذا فشل تكوين ال 4طهاه0 يقوم الأوراكل بحذف الملفات التي تكونت 
من خلال .OMF‏ 


يمكن الحصول على معلومات حول الملفات التي تكونت بطريقة gy DBA_DATAFILE ja OMF J‏ 
.VŞLOGFILE‏ 
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الول الثال 


تکوین الداتا بيس واسنةد ام 
الداتا ديكشينوري 


CREATING A DATABASE & 
USING THE DATA DICTIONARY 


PRE-CREATING STAGES 


عملية تكوين ال موو ط٤د(‏ تحتاج الى تخطيط وتحضير مسبق» يجب على ال 84( اعداد التالي: 
ه الحجم الكافي لكل من القرص الصلب ")ءز٥‏ 14۲4" و الذاكرة في السيرفر. 
٠‏ دراسة نوعية النظام "nءءر؟‏ ع«ذاوإءم 0" الموجود في السيرفر. 
ه وضع خطة لتوزيع الملفات في موقع التخزين لحماية ملفات ال مووطو٤ة0.‏ 


٠‏ تحدید اlعوامJ Initialization Parameters‏ وخاصة اÛ D(B_ BLOCK_ SIZE‏ الذي لا 
يمكن تغييره بعد عملية التنصيب. 


.S¥SD 84A و توفر ال‎ )Password File او‎ Operating System ) اختيار نظام الحماية‎ ٠ 


٠ه‏ معرفة اذا كان يراد تكوين مودط وه( جديدة أو يراد نقل ال مووطه٤ه(‏ الموجودة من نسخة 
أوراكل أقدم الى نسخة أجد › عند ذلك يجب استخدlم Data Migration Assista ıt Û|‏ 


ه تحديد الطريقة التي سوف يتم-بهابتكوين ال مودوطهاد الجديدة › إما عن طريق استخدام 
REA E DATABASE‏ € في ال.8 SQ‏ (تسمى الطريقة اليدوية) او عن طريق مووطو)54 
.Configuration Assistant‏ 
ه وضع خطة عملية دورية لإجراء عملي ال upں)ء84.‏ 
نقاط مهمة: 
1- ينصح بتوزیع ملفات ال ۴11۲ ٥٠)٠1‏ على مواقع مختلفة أ آقااص صلبة مختلفة. 
2- ينصح بتوزيع الملفات المتشابة في مجموعات ال وه 8٠0‏ الى مواقع مختلفة أو أقراص مختلفة. 
3- وضع نظام لتسمية الملفات ليتسنى ايجادها بسهولة. 


4- تفريق عناصر ال مووطهه( التي لها مراحل حياة مختلفة(قصيرة أو طويلة) الى مواقع مختلفة لكي يقل 
ما يعرف ڊlصp .Disk Fragmentation‏ 


5- تفريق ال وم1 اه١‏ وال وم×م لد[ الى كمءومءء1طه۲ مختلفة لتنظيم عملية ال utم† pu )/0 u‏ 1. 
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DATABASE CONFIGURATION ASSISTANT 


Create a Database, Configure Database Options, :يئتllب يمكن عبر ال(۸4 58°( اليم‎ 
.Delete a Database, and Manage Templates 


:CREATE A DATABASE 


للقيام بتكوين عوط هه جديدة أو القالب "ء)دام_٠1".‏ والقالب عبارة عن اختيار ال مووطوD5at‏ 
ام وحفظها لكي يتسنى استخدامها في موقع أخر. مثلاً يمكن ان يقوم الفرع الأساسي للشركة بتكوين 
قالب ال مووطه)ه( وتوزيعه على الفروع لتكوين ومووطه)ه متشابه في جميع الفروع. 

یمکن تکوین نوعین من القوالب "٥)4ام‏ ص۶" هما: 


٠‏ بدون ال 1ذ۴ و٤4(:‏ فقط اختيارت ال مءوطو٤ه(‏ دون الملفات (لمعرفة الاخيارات اضغط على 
Det"‏ سShow").‏ تکمن فائدته انه یمکن تغییر جمیع الأختیارات وال i٥‏ 114ھ i)iہ1‏ 
Parameters‏ بعد تکوین القالب ")ھام "۲em‏ . 


مع ال 1ذ۴ ه)54: يكون القالب/متكوناً من اختيارات ال مsوطو)هD‏ مع وجود ملفات ال و)54 
esاFi.‏ یتم تکوین ال t91 ۴ 11es‏ .و ال Red0 0g Groups‏ بشکل أوتوماتیکي» یمکن تغییر 
اسماء ومواقع ال (a٤a ۴٥s‏ Kولکن‏ لا یمکن حذف ال ی٥۴1‏ و٤4(‏ وتکوینھا من جدید وکذلك 
ینطبق الحال على یمم 1ط ھ۲ ٣یلا‏ یمکن تعدیل ال tion ۴a4 e)۶‏ izaاnitia]‏ بعد تکوین 
القالب ."Template'"‏ 


يوجد عدد من القوالب المعدة مسبقاً Nane"‏ مام "56 تظهر بالرسم 3.1: 


Ê :Oracle Database Configuration Assistant, Step 2 of 8 : Database Templates ا ادا‎ 


Select a template fromm the following listto create a database: 


Data YYarehouse 
Transaction Processing 
General Purpose 
New Database 


Show Details... 


cancel |] Help j ¢ Back 


رسم 3.1 
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بعد أن یتم اختیار أحد القوالب "ء)ھام ص٤۲۶"‏ يطلب اختیار اسم ال Database‏ سم Instance J|‏ 
المعرف بالرمز .S12‏ 


® Oracle Database Configuration Assistant, Step 3 of 8 : Database Idenbfication E ا×اداے‎ 


Specify the following database information 


An OracleQi database is uniquely kdlenêfed by a Global Oatabase Name, typically of the form 
“name.domalin" 


Global Database Narne 


Adalabase is referenced by al least one Oraclegi instance which is unéquely idenfified frorn arty 
omer instance on this computer by an Oracle System Identifier (SID) 


SI0: 


Cancel | Help ک‎ 


رسم 3.2 


في حال تم اختیار القالب "٥4طه٤D(a‏ wع.'‏ یتم اڅتیار الممیزات "۴٥۵٤۵۲٥۹"‏ التي ترید استخدامها في 
.Database Û‏ 


® Oracle Database Configuration Assistant, Step 4 of 8 : Database Options SÎ ا×اداے‎ 


Database Features |__ CUstom Scripts 
Select the features you want to configure fot ise İn your databa58 
Oracle Spatial 
ê Oracle Ultra Search 
- 
¥ Oracle OLAP Services 
fê Example Schemas 
WV Human Resources 
W Order Entry 
WV Product Media 
HW Sales Hisiory 


WP Shipping 


Additional database configurations... | 


Cancel | Help jut > j Finish 


رسم 3.3 
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المرحلة التالية يتم اختيار البيئة التي سوف يعمل بها ال مووطهاة0. 


O Oracle Database Configuration Assistant, Step 5 of 8 : Database Connection Oplons ا×اھاے‎ 


Select the mode in which you wart your database to operate by Gefalill 


1ë Dedicated Server Mode 
For each client connection the database will allocate a resource dedicated t0 serving only that 
dient. Use this mode when the number of total client connections is expected to be small of 
when clients will be making persistent, long-running requests to he database 


C Shared Server Mode 
Several client connections share a database-allocatled pool of resources. Use this mode 
when more than a small number of users need to connect to the database simultaneously 
while efficiently utilizing system resources. The Oracle multi-threaded server feature will be 
enabled 


Gif Shared Connectors Par3MIEIEFS 


cancel | Help | ¢  Bae¢k Einish | 


رسم 3.4 


بعد ذلك يتم تحديد عوامل Parameter File J| "Para eters"‏ iationاnitia]‏ المختلفة. 


© Oracle Database Configuration Assistant, Step 6 of 8 : Initialization Parameters 


uemoy RE 
C Typical 
Max. no. of concurrently connected USS 20 
Percentage of pşrsical rmemory (383 MB) for Oracle: [70 


Database Type: E at VATEPOUSIT 1 
SHOW GISFÎDUUOTI Of SGA 
ë Custom 
Shared Pool: 6 + [mMones 7| 
Buffer Cache: [20 2 [meres 7| 
Java Pool: 20 2 [meres 7| 


Total Memory for Oracle: 96 M Bytes 


All Inîtlalfzation Parameters... | File Locaton Variables 


Finish |) 


Cancel j) Help j 


رسم 3.5 
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يتم بعد ذلك عرض اسماء الملفات الفيزيائية وال ومءءدمءم1طه٠‏ ومواقعها ولديك الخيار بحذف أو اضافة 


ملفات اخری. 
ا×اداے F Oracle Database Configuration Assistant, Step 7 of 8 : Database SOF Sê‏ 
س 
#i] Controlîle Database Storage‏ 


J Tablespaces 
From ihe Database Storage p300, you can Specify storage parameters for he database 


GOI Oatafiles creation, This page displazys a kee sling and summary view (mul#-colurnn lists) to allow you 
@ORoOIback Segments % change and view the following objects 


@IRedo Log Groups 


ControlMiles 
Tablespaces 
Oaiafiles 

Rollback Segments 
Redo Log Groups 


“nne 


from ary object type folder, click Adid to create a new object To delete an object, select the 
specific object from within the object type folder and click Remove 


Important: Ifyou select a seed database template, you Will not be able to add or remove 
datafiles, tablespaces, or rollback segments. Selecting a seed template allows you 10 only 
change the following 


» The name ofthe database 
» Destination ofthe Gatafiles 
» ControlMiles or log groups 


File Location Variables... 


Cancel Help ¢ Back Neo > Einish 


رسم 3.6 


في المرحلة التالية يتم اختيار نوعية التكوينء هل تريد تكرين”مء4طهه( أو تريد تكوين فقط قالب 
"ateاpصem‏ ا" أو هل ترید تکوین جمل وام Q1 Se‏ ۹الت یمگن'استخدامھا مع مر 
.CREATE DATABASE‏ 


® Oracle Database Configuration Assistant, Step 8 of 8 : Creation Options 


Select the following database creation options: 
FF Create Database 


` Save as a Database Template 


Name: 77 


Description: 


` Generate Database Creation Scripts 


Des§nation 
Directory: 


C1oracleTiora92adminirvewdatalscripts BrOWSE 


Cancel ) Help j 3 Back Next 


رسم 3.7 
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:CONFIGURE DATABASE OPTIONS 


يمكن تعديل ال مووطهtه(‏ التي تم تكوينها سابقاً من ناحية ال وه ں٤ه٥۴‏ ٥1ء١0‏ والبيئة التي تعمل عليها 
„(Dedicated Server gy Shared Server)‏ 


:DELETE A DATABASE 


لحذف مو4 طو)ه تم تكوينها سابقاً 


:MANAGE A TEMPLATE 


یمکن استخدامها لتکوین قالب "٥)14م "۲٠.‏ أو لحذف قالب "دام "۲٤٥"‏ موجود. عند تكوين قالب 
"ateاpصe‏ ا" جدید یمکن الاختیار بین ثلات خيارات هي: 


من قالب "٥٤ھامص٥۲"‏ آخر موجود» اذ يمكن تعديل مواصفات القالب "٥)دام "۲٤٥‏ لصنع قالب 
"ateاemp""‏ جدید. 

من مواصفات 1e‏ طه)ھ( موجودق(تم تکوینها سابقاً) › اذ یمکن تکوین قالب "٥٤ھام‏ ص٤۲"‏ 
مشابه لمواصفات ال 4٥‏ ط544 ولکنادون ملفات ال 4٤4 ۴es‏ 0. 

ه من موو طوtه(‏ موجودة» اذ يمكنتكۆين نسخة مطابقة ل مووطوt)ه(‏ موجودة مع ال وا54 
6 وجميع البيانات. 


: Oracle Database Configuration Assistant, Step 2 of 8 : Template 


ا×اھا۔ 


Select the template management operation you want to perform: 
1ë Create a database template 
ê From an existing template 


C From an existing database (structure only) 
The template will contain structural information about the source database including 
database options, tablespaces, datafiles, and initialization parameters specified in the 
source database. User defined schemas and their data will not be part ofthe created 
template. 

C From an existing databaşe (structure as well as data) 
The ternplate wîll contain the structural information a5 well a5 physical datafiles specified 
in the source database. Databases created using such a template will be identical to the 
source database. User defined schemas arid their data will be part of the template. 


C Delete a database template 


cancel j) Help } $ Back 


رسم 3.8 
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CREATE A DATABASE MANUALLY 


يمكن تكوين ال وط هه بطريقة يدوية باستخدام !لمر .CREATE DATABASE‏ 
الخطوات المتبعة تتلخص بالتالي: 


.Database Jly Instance Û تحديد اسم‎ 

تحدید ال Character Se٤‏ aseطataط‏ التي سوف نتطرق لها لاحقاً في فصل أخر. 
تجjı‏ مذف .Initialization Parameter File J|‏ 

تشغيل ال مه ط هه في الوضعیة N1‏ ا0 ›NNOM‏ عبر ال 84 SD$؟¥S.‏ 

.CREATE DATABASE !لمر‎ ةlتك‎ 

. Data Dictionary Û| jڍgكîl‎ SQL SCRIPTS J| تشغيل‎ 


ملاحظة: اذا كنت تقوم بتكوين ال مو ط٤(‏ على نظام ال N]×‏ ل یجد تحدید ما یعرف یاسم ال 
ling Environmental Variables‏ : 


.'"آ٣ ۴ہ‎ ۲۲٥۲" هو الموقع "راه)ء٥1۲٥" الذي يحوي کل ملفات الأوراکل‎ :0RACLE_BASE 
وهنا يتم تخزين كل نسخ الأوراكل المختلفه "ور مذوإمء۷".‎ 


.Oracle Software Û gãga :ORACLE_HOME 


:0RACLE_SID‏ تحدد اسم ال ٥e‏ ھ)8 ا قالذي یجب ان یکون غیر متشابه مع اسم "٥٥‏ ه٤ی"!]‏ آخر. 


.'"5efھں[٤" غیر التي تم تحدیدھا مسبقاً‎ "ata Character Se)" لتحدید‎ :٥RA_ N3 


۳ : مواقع برامج الأوراکل مثل ال 8ا1۲ »S@‏ وان#المفترض ان تکون 
.SORACLE_HOME\bin‏ 


:1D L[]BRARY_ PATH‏ ملفات أخری تسمی es‏ ]ز۴ 1r ary‏ eاOrac‏ وعادۃ ما تکون 
.SORACLE_ HOMEI\lib‏ 


يمكن تكوين مو4ط و4( بشكل يدوى باستخدام القاعدة التالية: 


CREATE DATABASE [name of database] 
[CONTROLFILE REUSE] 
[LOGFILE [GROUP number] C1 


[MAXLOGFILES number] 
MAXLOGMEMBERS number] 
MAXLOGHISTORY number] 
MAXDATAFILES number] 
MAXINSTANCES number] 
ARCHIVELOG | NOARCHIVELOG] 
CHARACTER SET char] 
[NATIONAL CHARACTER SET char] 


[ 
[ 
[ 
[ 
[ 
[ 


[DATAFILE C1 [C2]] 

[DEFAULT TEMPORARY TABLESPACE tablespace_name C1 [C3]] 
[UNDO TABLESPACE tablespace name DATAFILE C1 [C2]] 

[SET TIME _ ZONE [time_zone region]] 
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أما ال الرموز ال €1 K3.€2‏ فترمز الى جزء من القاعدة تم تخفيفة الى رموز لسهولة قراءة القاعدة: 
'"filename' [SIZE number] [K | M] [REUSE] =C1‏ 


[AUTOEXTEND OFF | ON [NEXT number [K | M]]=C2 
[MAXSIZE UNLIMITED | number [K | M]]] 


EXTENT MANAGEMENT LOCAL UNIFORM [SIZE number] [K | M] =C3 
اي انه في الجملة الثالثة تكون القاعدة:‎ 


[LOGFILE [GROUP number] 'filename' [SIZE number] [K | M] [REUSE] 


ملاحظة: جملة ال CREA E D۸1۸ BASE‏ هي الجملة الإلزامية الوحيدة و الباقي اختياري. 


ملاحظة2: عند عدم استخدام كلمة ال S17۴٤‏ يجب استخدام كلمة ال S۴‏ ل ۸٤‏ والعکس صحيح. 
أما أوامر القاعدة فهي : 


:]name of database]‏ اسم ال مsوطوtهD‏ المراد تكوينه. في حال عدم كتابته يؤخذ قيمة العامل 
.DB_NAME‏ 

B0N "ROLFILE REUSE] *‏ ]یمکن استخدامھا لطلب اعادۃ استخدام "0e Wr İ)٥''‏ 
ملفات ال Contr01 ۴1e‏ المعرفة في ال ]n¡itialiation Para meer ۴1e‏ عوضاً عن تکوین 
ملفات جديدة. 

:]MAXLOGFILES number] e‏ تحدد(الْعدد الأقصی لمجموعات ال 10g ۴16s‏ 8۵0 التي 
يمكن تكوينها في ال موو طه)د( على مدى حياةرالمء4طه)04) العدد الأدنى هو 2. 

:]MAXLOGMEMBERS number]‏ تحدداالعدڈ الأقصی لملفات ال ع0 ۸d0‏ ضمن 
المجموعات. 

:][M A XLOGHISTORY number] °‏ تحدد عدد Archived 0g ۴¡[e8@(‏ التي تسخدم في 
عılnة .Media Recovery JI‏ 

U۲0 EXTEND] *‏ ۸]: سوف نتطرق لھا لاحقاً. 

:]MAXDATAFILES] °‏ تحدد العدد الأقصی من ال ۴1٥١‏ و( الذي يمكن تكوينه على مدى 
حياة .Database J|‏ 

:][MAXINSTANCES] °‏ تحدد العدد الأقصى من ال ومعم و٤ءه!]‏ الذين يستطيعون العمل على ال 
6 في نفس الوقت. 

:]CHAR ACTER SET char]‏ سوف نتطرق لھا لاحقاً. 

:]NA 10 NAL CHARACTER SET] °‏ سوف نتطرق لھا لاحقاً. 

Default Temporary ÛJI jıgSîl :[DEFAULT TEMPORARY TABLESPACE] 
التي سوف نتطرق لها لاحقاًء اذا لم تحدد يقوم الأوراكل بتكوينها للمستخدم.‎ r ablespace 

:][U[NDO TABLESPACE] °‏ لتکوین ال ceھےsp٥1‏ اھ٣‏ 40 €n‏ التي سوف نتطرق لھا لاحقاً. 

.D ط44‎ 4e تحدید وقت ال‎ :]SE۲ "]|ME_ZONE] 
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مثال تطبيقي 3.1: 


CREATE DATABASE db01 

CONTROLFILE REUSE 

LOGFILE 

GROUP 1 ('C: \oraclelora92\oradata\db01\log101.log') SIZE 10M 
GROUP 2 ('C: \ oracle\ora92\oradata\db01\log201.1log') SIZE 10M 
GROUP 3 ('C: \ oracle\ora92\oradata\db01\log301.1og') SIZE 10M 
MAXLOGFILES 4 

MAXLOGMEMBERS 2 

MAXLOGHISTORY 0 

MAXDATAFILES 254 

MAXINSTANCES 2 

ARCHIVELOG 

CHARACTER SET AL32UTFS 

NATIONAL CHARACTER SET AL16UTF16 

DATAFILE 'C: \oraclelora92\oradata\db01\system01.dbf’ SIZE 100M 
AUTOEXTEND ON NEXT 5M MAXSIZE UNLIMITED 

UNDO TABLESPACE UNDOO01 

DATAFILE 'C: \oracle\lora92\oradata\db01\undg01.dbf' SIZE 40M 
DEFAULT TEMPORARY TABLESPACE TEMPODTEMPFILE 
'C: \oracle\lora92\oradata\db01\temp01.dbf' SIZE 20M 

EXTENT MANAGEMENT LOCAL UNIFORM SIZE 128K 

SET TIME_ZONE = 'CANADA /YUKON! 


9 


الأخطاء التى قد تؤدي الى فشل تكوين ال مووطه٤ه0‏ بشكل بدىئ: 


ه أخطاء في كتابة جمل ال ا@S.‏ 
ه طب تكوين ملفات موجودة مسبقا (تأكد من ان اسم الملف غير مستخدم) 
ه مشاكل أو اخطاء ناتجة من نظام التشغيل ."Operating Sy)"‏ 


لأعادة تكوين ال مووطه)ه0 بعد محاولة فاشلة يجب: 


.]nst4 "ce اغلاق ال‎ 

حذف أي ملفات تکونت من ال )PREA €٤ 5۸1۸ 8۸S۴‏ التي فشلت. 

تصحيح سبب الفشل › مثل تعديل جملة ال 5Q1‏ التي تحوي أخطاء. 

تشغيل ال ٥#‏ واء"[ في وضعية ال N0N ٥0ا0 N1‏ والقیام تکوین ال م2sط‏ هه( من جدید. 


ملاحظة: لا يتكون ال رإور ناء¡ واه بعد الانتهاء من تكوين ال مءدطه)ه( بشكل يدوي» ولكن يتم 
تكyيù .VŞDATAFILE ÛJI Jûa Dynamic Views J|‏ 


تذكر: تغيير كلمة السر لكل من المستخدمين S۷8‏ و 9۷5S۲ ٤۷‏ لأخذ الأمان. 


تذكر: ان استخدام ال Oracle Managed Files (OMF)‏ يسهل عملية تکوین ال seھطھ†غDa.‏ 
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DATA DICTIONARY 


يعتبر ال ره۸ ٥ا¡(‏ وو أحد أهم مكونات ال مءوط ه0 اذ يتكون من مجموعة من ال 16s‏ ط۲ وال 
التي تحتوي معلومات قيمة عن ال موو طه)04. تستخدم ال رور هذا و٤(‏ لقراءة البيانات 
فقط ولا يمكن تعديل بياناتها بواسطة ال ۰084 ولكن يقوم ال اه0 بتعديل البيانات الموجودة عند حدوث 
أوامر ال .Data Definition Language (DD)‏ یستخدم الأوراکل ال راہ ہذاc D4)‏ ایضاً عند 
طلب المستخدم الدخول الى Database Û‏ < | يقوم بالتأکد من وجود اسم المستخدم وبيانات المستخدم مثل 
.User Privileges ÛJI‏ 


یتکون ال راھ ه1¡( 4)4( من عنصرین هما: 


:B ASE "ABLES‏ یتم تخزین بیانات حول ال مط هه( في ال 16ا۲۵ 4۵ 8. تعتبر ول 
جزء "٥زط0"‏ من ال مء4طه)ه( يتم تكوينه» ويتم تكوينها بشكل أتوماتيكي من قبل الأوراكل 
باستخدام الملف ")م ذء؟" المسمی باسم وط.[ء. لا يجب تعديل ال و6[اطه١‏ م84 أوالعبث بها 
لأنها ضرورية لتشغيل ال مووطه)ه0/ ولكن يمكن تعديل واحدة فقط وهي ال ۸5$ › مع العلم أنه 
يتم تخزین البيانات في ال 16s‏ اه م84 بشكل مشفر. 

NARY [ENS‏ 10 ]1 : تقوم بتلخيص وترتيب بيانات المخزنة في ال وماطه1 م844 لكي 
تسهل استخراج البيانات و قرائتها) يتم تكوينها باستخدام الملف ")مذء؟" المسمى باسم 
.catalog.sql‏ 


:Data Dictionary Û| ٽlنlڊ‎ 


يوفر ال رإه«هاء¡ وه بيانات مهمة حول: 


Tables, Indexes, J| Jia Database J| "O0bjec)ءs'" معلومات تفصيلية حول جميع عناصر‎ 
و غيرھا.‎ Views, Synonyms, Data files, Control Files 


بيانات حول المساحة المشغولة والمساحة الفارغة في ال مووطه)ة0. 
بيانات حول المستخدمين "'١إمءلا"'".‏ 

بيانات تفصيلية لل وم عم]1ز آ۴ و ال وم801 الممنوحة لكل مستخدم. 
بيانات حول ال جزل ں۸ التي سوف نتطرق لها في فصل أخر. 


. Integrity Constraint ÛJI بياناٽ حول‎ 
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QUERYING DATA DICTIONARY 


تتوزع ال sسعذ۷‏ راه« ماع1 الى ثلاث مجموعات عي: 


_8۸(: تحتوي ال ع۷1 على جميع بيانات العناصر "ء٤ءeز(0"‏ في ال ۾4sط 04٤4‏ وهي 
خاصة لل D8۸‏ و کل مستخدم لدیه ال وەعم 1ر1٥‏ اللازمة للدخول الى بياناتها. 


٠ه‏ _11: تحتوي على بيانات حول جميع العناصر "ءءء زط0" التي يستطيع المستخدم استخراج 
البيانات منهاء سواء ما كان منها ضمن ال .1ء5 الخاصة بالمستخدم أو مستخدمين أخرين أو 
.Public Schema ÛJI‏ 

15SER _ ٠‏ : تحتوي على بيانات حول العناصر "٠زط0"‏ التي يملكها المستخدم (أي العناصر في 
ال ٣ع‏ طء؟ الخاصه بالمستخدم). 


يمكن معرفة جميع ال وسء۷1 المتوفرة في ال رادم اء¡ و)د( من خلال البيانات المعروضة من ال 
.DICTIONARY view‏ 

مثال تطبيقي 3.2: 

SELECT * FROM DBA_OBJECTS; 

SELECT * FROM ALL OBJECTS; 

SELECT * FROM USER_OBJECTS; 


SELECT * FROM DICTIONARY; 


DYNAMIC PERFORMANCE 
بتسجیل بیانات حول عمل ال مئه طه0t في‎ 0۲4٥1۵ S۷٥۲ طوال فترة عمل ال ۲ئ4 ط ه٤۰04 یقوم‎ 
الذاكرة على شكل وع1طه١ وعند اغلاق ال مووط وه أو اغلاق السيرفر تضيع البيانات من الذاكرة.‎ 
من ضمن ال 3٥1ء5 5۷8› وهي تستخدم بشکل اساسي‎ Dynamic Performance View تعتبر ال‎ 
عليھا.‎ Data Manipulation Language(DML) لمراقبة ال مووطه د ولا يسمح القيام بأوامر‎ 


لمعرفة ال و٥۷‏ المتوفرة يمکن استخدام ›V$FIXED_ TABLE‏ ولمعرفة ال وص uاهC٤‏ ضمن ال 
.VŞINSTANCE pدختwاl Views‏ 


. ¥$ jزمرلاب‎ hynamic Performance Views Ji jمری ملاحظة:‎ 
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الفهسل الر ايع 


ملفات الكننرول و الريدو لوج 


CONTROL & REDO LOG FILES 


CONTROL FILE 


یعتبر )٥٤۲٥1 ۴1٥‏ ضروري جد لتشغیل وعمل ال وط هه۰0 حیث تتم قرائته من قبل ال ما04 
إمServ‏ قبل بدء تشغيل ال مءوطه٤4(/»‏ اذ يحتوي على بيانات مهمة حول ال مءوطه)ه مثل اسماء 
ومواقع ملفات ال .D4a ۴1٥‏ تتم تغیر بیاناتھ أو تجدیدھا ")ےل ملا" عبر ال Seer‏ 41ا0 فقط › 
اذ لا يستطيع أي مستخدم أو ال D84‏ القيام بهذه المهمة. 

یتم تکوین ال ۴1٥‏ 1٥٤رہ‏ بعد تکوین ال se‏ طھ٤ھD‏ مباشرة ولا یستطیع ال C٥۸٤1 ۴1٥‏ الواحد 
العمل على أكثر من مووطه)ه واحدة › ويلزم ٥ذ۴‏ 01٠إ)٠)‏ واحد فقط على الأقل لتشغيل ال ٭ووطه)54 


ملاحظة: تسمى عملية تكوين أكثر من نسخة متطابقة من ملفات ال C٥٤٥1 ۴1٥‏ (ينطبق الحال على ال 
ع0ا R ed0‏ ايضا) بعملية ال ×م[م نا1 ٠‏ ويفضل توزيعها على مواقع أو اقراص صلبة مختلفة. 


ملاحظة2: ملفات ال ۴1e‏ 1٥)رهC‏ من نوعية ال رھہ81. 
تذکر: تتم قراءة ملفات ال ۴1۲ ٥1)01‏ رفي مرحلة ال .Mou n‏ 


تذکر2: ملف ال SP ۴1٤‏ من نو عیۂ ل٣ھ .8i‏ 


یوجد عوامل ''۶ا٥)e‏ ,4و۴" تحدد حجم ال ٤01 ۴11e‏ ہ €٥‏ وھی: 


MAXLOGFILES 
MAXLOGMEMBERS 
MAXLOGHISTORY 
MAXINSTANCES 
MAXDATAFILES 


یحتوی ال ٥ا۴‏ 01إ٤ره٥‏ على البيانات التالية: 


.Control File ÛJI qi التي يعمل‎ «ata طوaوم اسم ال‎ 

تاریخ وتوقیت تکوین ال seوطه)04.‏ 

.Redo Log ÛJI و‎ Data ۴¡[¢s اسماء ومواقع ملفات ال‎ 

.Tablespaces JI slaw 

.Checkpoint Û| معلومات حول‎ 

„Archived Log File Ja معلومات‎ 

معلومات حول عملیة ال up‏ )4 8. 

توقیت بدء و توقف ال 1d0 Seg")‏ ا. 

الرقم الحالي ل 10g Sequence Number‏ والذي یتم تخزینه عند حدوث طعt¡سS‏ 0gا.‏ 


تذكر: يحتوي ال ۽a1erS15.10۾‏ ايض J|ذآJ .Log Sequence Number‏ 


64 


MULTIPLEXING CONTROL FILES 


للحماية من أية خلل قد يحدث لل موو ط هاه نتيجة تعطل ال ٥ذ۴‏ [0٣٤رهC‏ ينصح بشدة بالقيام بعملية ال 
Multiplex‏ لل ۴1e‏ 1اCntro‏ بيحث يتم تخزين النسخ المتطابقة في مواقع تخزين مختلفة لكي يتسنى 
استعادة ۴1 )٥1)۲٥1‏ في حال تعطله أو ضياع بياناته. 

للقیام بعملیة ال s٥1من)اں ۷M‏ یجب استخدام إما ال 9SP ۴1٤‏ أو ال a٣٥.)iہi‏ . 


ملاحظة: یمکن عمل ثمانیة نسخ لل .C٥۸)٣01 ۴1٥‏ 


:MULTIPLEXING USING SPFILE 
يجب إتباع الخطوات التالية:‎ P۴1۴ بواسطة ال‎ Contro1 File Multi pاes للقیام ب‎ 
كما في المثل التالي:‎ S۶۴1۴ تغییر ملف ال‎ 
ALTER SYSTEM SET CONTROL_FILES = 
(...lora01\oradata\db01\ctr001.ct1', '...lora02\oradata\db01\ctr002.ctl', 
'...lora03\oradata\db01\ctr003.ctl', '...lora04ofFadatd\db01\ctr004.ct1') 
SCOPE=SPFILE; 


ه لكي تتم التغيرات يجب اغلاق ال هة ط464( بكتابة التالي: 
SHUTDOWN;‏ 


نسخ ملف ال ۴1۲ ٥٠١)۲01‏ الى المواقع التي جدكت بالنقطة الأولى (القيام بعملية النسخ كما في 
نظام التشغيل › اي في الویندوز يستخدم الفأرة مع ٥)0۴¥۷‏ و .PASTE‏ 


٠‏ تشغيل ال موو طه)ه بكتابة التالي: 
STARTUP‏ 


:MULTIPLEXING USING init.ora 
بواسطة ال aإ0.٤زم يجب إتباع الخطوات التالية:‎ Contro1 File Multipا‌s للقیام ب‎ 


ه يجب اغلاق ال مووطهاه بكتابة التالي: 
SHUTDOWN;‏ 


e‏ نسخ ملف Control File JÛ|‏ الى المواقع الجديدة التي سوف تحدد في النقطة الثالثة. 
٠‏ تعديل العامل "Parameter"‏ ROL_FILESآ0N()‏ في ملف ال ۲4٥.)زم1‏ كما في المثال: 
CONTROL_ FILES =(...\disk1\ctr01.ctl, ...\disk2\ctr02.ct1)‏ 


تشغیل ال eئھط04)4.‏ 


65 


ملاحظة. استخدام الثلاث نقاط )...( في المثال السابق للاختصار فقط, 
:USING OMF‏ 


یمکن تسھیل إدارة ملفات ال ٥٥)٥1 ۴1e‏ باستخدام ال Managed ۴ ¡1es‏ eاacا0.‏ یمکن تکوین ال 
Contro1 Files‏ طبقاً لطریقة ال M۴‏ بشكل أتوماتيكي عند تكوین ال م4 طه)هD‏ اذا لم يتم تحديد العامل 
Parameter Files JI yû CONTROL_FILES "Parameter"‏ iationاnitia]‏ وتم تحدید 
.DB_CREATE ONLINE LOG _ DEST _ n OMF JI "Parameters" Jale‏ 

بعد تکوین ال ٥٥۸٤۲٥1 ۴1٥‏ بطریقة ال M۴‏ یجب تسجیل اسم وموقع ال ٥٥٥٤۲٥1 ۴1٥‏ في ال 
PFE‏ » اما اذا کنت تستخدم ال 9P ۴1۴٤‏ فإن الاسماء تسجل بشکل اتوماتیکي. 


:DATA DICTIONARY & CONTROL FILE 
عبر:‎ Data Dictionary Û من‎ Control File یمکن استخراج بیانات ال‎ 


:V$ŞCONTROLFILE ®‏ تعرض اسماء ال Con tr01 ۴ ¡1es‏ والحالة الحالية )§S1۸115(‏ اذ 
انها دانما فارغة إلا في حال ضیاع ملف من ملفات ال C٥۸٤٣ ۴1٥‏ فتصبح .1IN۷۸ 11D‏ 


SELECT STATUS, NAME FROMeVŞEONTROLFILE; 


PARAMETER‏ : تعرض ياء وقیم ''ومں[ ے۷" جمیع العوامل ع۸٣۶۸"‏ من 
ضمنھا طبع .Control Files JI‏ 


SELECT NAME, VALUE FROM VŞPARAMETER 
WHERE NAME = 'control_files'; 


:6CONTROLFILE_RECORD_SECTION °‏ تعرض بيانات عن الأجزاء المختلفة من 
.Control File Û!‏ 


SELECT TYPE, RECORD_SIZE, RECORDS_TOTAL, RECORD_USED 
FROM V$ŞCONTROLFILE_RECORD_SECTION; 


C٥۸٤۲01 یمکن استخدام هذه للحصول علی مواقع واسماء ال وم۴1‎ : SHOW PARAMTER 


SHOW PARAMETER CONTROL FILES; 


ملاحظة: یمكن الحصول ایضاً علی اسماء ال ٥٥۸٤٥1 ۴6s‏ بعد تکوینها من ملف ال ع41۵۲۲۹10.[0. 
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REDO LOG FILES 


تعتبر ملفات ال وم1 0ء8 ضرورية جداً لعمل ال مووطه)ه ٠‏ اذ يتم تخزين كل ما جرى ويجري على 

البيانات من تغيرات لکي يتم استعادة البيانات "Recovery"‏ في حالة حدوث ضياع للبيانات عند حدوث عطل 

مفاجئ. تنقسم ملفات ال عم 8٥40‏ الى مجموعات "وم ںهإ6" كل مجموعة تحوي أعضاء 

»"M embers"‏ و الأعضاء "ءإءطmع۷"‏ ضمن المجموعة الواحدة عبارة عن نسخ متطابقة 

"كءزم ه۳" تحوي على نفس البيانات ويتم نقل البيانات لها في نفس الوقت. 

يتطلب الأوراکل على الأقل مجموعتین من مجموعات ال [0g ۴1٥s‏ ٥ء۸‏ وکل عضو "۲ءطصإ ء۷" ضمن 

المجموعة يكون له نفس الحجم وذات .Log Sequence Number J‏ 

يقوم الأوراكل بواسطة ال 1G R‏ بنقل بيانات Redo Log Files JI ll Redo Log Buffer J|‏ حیث 

تتم الكتابة على مجموعة واحدة فقط وعندما تمتلئ المجموعة الأولى يقوم ال ۷R‏ 16 بكتابة البيانات في 

المجموعة الثانية وبعد إمتلاء المجموعة الأخيرة يعود ال ۷R‏ 116 بالكتابة في المجموعة الأولى › وتسمى 

هذه العملية بال طء)اس؟ ع٠1‏ وتسمى المجموعة التي يتم نقل البيانات لها باسم المجموعة الحالية أو 
."Current Online Redo Log Group"‏ 


ملاحظة: يمكن تحديد الحد الأعلى للمجموعات و الأعضاء بواسطة M۸XL0⁄GMEM BERS‏ و 
.CREATE DATABASE JÛ ةlaج „ê MAXLOGFILES‏ 


تذکر: یتم تخزین بيانات حول ال b0g/S wite‏ في „Alert Log File Û‏ 


LOG SWITCH LOG SMTCH 
سے‎ 


GROUPZ2 


GROUP1 GROUP3 


کل مجمو عة ۴1e‏ ع10 Red‏ معرفة برقم ممیز یسمی [0g Segue 1ce Nur‏ یمنحھ الأوراکل لکل 
مجموعة عند بداية كتابة البیانات بها حيث يتم تجدید الرقم "٤٤اس‏ ام0" كل مرة يتم إعادة استخدام 
المجموعة. 
تذکر: يتم تخjıj [0g Sequence Number‏ في: 

Control File 

Data Files Header 
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Alert Log File ° 


تعرضنا لل ٤مزهم‏ )ء٥1٥‏ في الفصل الأول وذكرنا انه يقوم بكتابة ال 10g Sequence Number‏ في ال 
.C0ntro1 File‏ ونتطرق لل ٤"iمم ec)‏ ط€ مرة أخرى لأن العلاقة بین Log Jly Checkpoint J|‏ 
Switch‏ متزامنة بحیث عند حودث ال طعt¡سS‏ ع٥[‏ تحدث عملي ال ٤م¡ەم Check‏ . ویقوم اJÛ Alert‏ 
0g Fe‏ بتخزین معلومات حول ال ٤ہزممck٥طC‏ کما یقوم بذلك مع ال طc)س؟‏ ع٥[‏ ولکن یجب وضع 
العامل "Para meer"‏ التاذأي CHECKPONT_TO_ALERT‏ 106 في حالۂ eںu‏ ۲ عکس الحالة 
الإفتراضية ")[uوfء5"‏ وهي ٥ء[۴.‏ 
يمكن ان تحدث عملية ال ٤م‏ زمم C1)‏ عند: 

.Log Swit حدوث عملية‎ 

.ABORT عند إغلاق ال مووطه٤هD بأي حالة عدا ال‎ ٠ 


٠‏ عندما يحدد العام ۴۸S۲ START_MTTR_TARGET "Parameter"‏ الذي یحدد کمیة 
البیانات المتغیرة '' B٣١‏ ر" التي يستطیع ال (8W‏ کكتابتها. 


.4.1 كما في المثال‎ 5Q1 عندما طلب ال 84( يمكن القيام بهابكتابة جملة‎ ٠ 
ALTER TABLESPACE OFFLINE NORMA. التالي:‎ 8Q1 عندما تكتب جملة ال‎ ٠ 
.ALTER TABLESPACE READ ONLY :ةيلlتll‎ SQ عندما تكتب جملة ال‎ ٠ 


.ALTER TABLESPACE BEGIN BACKUP :ةيllتl‎ SQ J| عندما تكتب جملة‎ 


مثال تطبيقي 4.1: 
للقيام بعملية ال ٤رزمم‏ )٥ء1٤‏ بواسطة ال SQ‏ يجب كتابة التالي: 
ALTER SYSTEM CHECKPOINT;‏ 


اذا تم تحديد العامل ")ء۳ "Para‏ 
FAST_START_MTTR_TARGET = 400‏ 


يدل على عملية ال رم هءءR‏ يجب أن لا يزيد وقتها عن 400 ثانية حيث أن من ضمن عملية ال 
.Log Switch J| ales Checkpoint Û| alae Recovery‏ 


يمكن آن يتم طلب عملية ال طء٤زس؟‏ ع10 ايضاً بواسطة ال SQ‏ عبر التالي: 


ALTER SYSTEM SWITCH LOGFILE; 
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MAINTAINING REDO LOG FILES 


سوف نتطرق الى عدد من المهام التي یمکن اجرائھا لل و٥۴‏ ع10 R٥۵١‏ لحمایتها أو لتعدیلها. 
:MULTIPLEXING‏ 


لحماية ال ase‏ ط وھ( یجب القیام بعملية ال ×م[مذ)اںM‏ علی ال 6ا۴ ۽٥[ Red0‏ › بحیث یقوم ال 
6W۷R‏ 1 بكتابة ذات البيانات على النسخ المتشابه في نفس الوقت. كل النسخ المتشابه تكون ضمن مجموعة 
"Grup"‏ و يطلق على النسخ المتشابه اسم وء طا_ء. يفضل فصل النسخ المتشابه عن بعض وابقائها 
في موقع مختلف أو على قرص صلب مختلف (أو أي وسيلة لحفظ البيانات) كما في الرسم 4.1 يظهرأن 
الأعضاء (۲2ءطnءM‏ , ۲1ءMemb)‏ في ذات المجموعة على قرصين مختلفين (k2ء¡0‏ ,1ء0i).‏ 

في حال عدم توفر أي عضو "١ء‏ طد_ء]" من أي مجموعة لنقل البيانات إليه يتم اغلاق ال #وءوطو٤54‏ 
تب عمılة .Instance Jİ Recovery‏ [ 

يمكن تكوين أكثر من مجموعة من مجموعات ال ۴1 ع10 8٠40‏ عند تكوين ال مsوطه٤ه(‏ أو يمكن 
اضافة مجموعة أخرى لاحقاً. 


نقاط مهمة فى عملي Multiplex J|‏ 


o‏ ينصح بتفريق الأعضاء ضمن الكجموجة الواحدة الى مواقع أو اقراص صلبة مختلفةء لكي لا يحدث 
أغلاق لل مووطهاه في حال تعطل/القرص الصلب الذي يحوي الملفات. 


ينصح بتفریق ال On اine Red 10g ۴es‏ عن ال Archived 10g ۴es‏ الی اقراص 
مختلفة أو مواقع مختلفة لكي لا يحدث تداخل بين يعمل ال 1G WR‏ و .ARCn Û‏ 


٠‏ ينصح بتفريق ملفات ال عم 8٠0‏ و ملفات ال ۴116s‏ و٤(‏ الى مواقع أو اقراص مختلفةء لكي 
لا یحدث تداخل بین .LGWR Jl DBW n Û‏ 


:SIZING ONLINE REDO LOG FILES 
ھو 8× 50 › ما اکبر حجم ھو آکبر حجم یسمح بھ‎ ۸٤۵٥ عہ.1‎ ۴٥ صغر حجم یمکن ان یکون علیة ال‎ 
٤ [ .)70N]× نظام التشغيل (مثل ویندوز أو‎ 
یمکن لل 8۸( تحدید حجم ال و٥۴1 ع0 40ء8 بالأخذ بالمعطيات التالية:‎ 
.S)ه١وعم‎ (۷e ه الجحم المتوفر على القرص الصلب أو أي‎ 
التي يمكن أن تحدث.‎ hecekpoin) و ال‎ 10g Swit عدد مرات ال‎ 


ه الحجم المتوقع لل وما) ع ل٠8‏ والذي يعتمد على العمليات التي تجري على ال مئوطو)4و5 
والتي تؤدي الى تغيير البيانات. 
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:ADDING ONLINE GROUP 
:4.2 في حال وجد ال 84( أن ال مووطه)ه بحاجة الى مجموعة جديدة › يمكن تكوينها كما في المثال‎ 
:4.2 مثال تطبيقي‎ 


ALTER DATABASE ADD LOGFILE GROUP 4 
("...loradata\dbO01\log11.log' , '...loradata\db02\log12.log') SIZE SM; 


:ADDING ONLINE MEMBER 
يمكن اضافة أعضاء جدد للمجموعات الموجودة باستخدام القاعدة التالية:‎ 


ALTER DATABASE [database's name] ADD LOGFILE MEMBER 
['filename' [REUSE] , 'filename! [REUSE], ....] 
TO [ GROUP number | (filename, ilename', ...); 


في حالة وجود اسم العضو على الجهاز وبنفسل الحجم (أي الملف موجود مسبقاً) يجب استخدام كلمة 
گا ۴E‏ اما بالنسبة الى الجملة الأخيرة فلديك أخياراان إما أن تذكر رقم المجموعة أو اسماء الأعضاء 
الحاليين في المجموعة التي تريد اضافة عضو جديد لها: 


ملاحظة: يمكن اضافة عضو جدید باستخدام .Console JI û Sîorage Manager J|‏ 
مثال تطبيقي 4.3: 


ALTER DATABASE ADD LOGFILE MEMBER 
'...loradata\db04\log41.log' TO GROUP 1, 
'...loradata\db04\log42.log' TO GROUP 2, 
'...loradata\db04\log43.log' TO GROUP 3, 
'...loradata\db04\log44.log' TO GROUP 4; 

أو بالطريقة الثانية: 
ALTER DATABASE ADD LOGFILE MEMBER‏ 
'...loradata\db04\log14.log'‏ 
TO ('...loradata\dbO01\log11.log' , '...loradata\db02\log12.log' ,‏ 
'...loradata\db03\log13.log');‏ 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال 01eی" C٣0‏ عٹبر .Standalone‏ 

اضغط على اسم ال مءوطهه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم و كلمة السر مع التاكد من اختيار S۷5S584‏ عوضاً عن إوصإه.. 
اضغط على .Storage Manager J|‏ 

.Redo Log Groups JE !ضط‎ 

اكتب اسم العضو الجدید ثم اضغط رامم۸. 
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:DROPPING ONLINE LOG GROUP 


اذا أردت زيادة حجم أحدى مجموعات ال و0 0ء8 يمكن ازالة المجموعة وتكوين مجموعة جديدة بحجم 
أكبر» حيث تستطيع ازالة مجموعة من مجموعات ال ع0 هلء 85 باتباع القاعدة التالية: 


ALTER DATABASE [database' name] 
DROP LOGFILE [GROUP number | ("filename',....); 


يجب أن لا تكون المجموعة المزالة هي المجموعة الحالية "٤٠٠إإں٤"‏ أو ان تكون في وضعية ۸)۷٥‏ بل 
يجب أن تكون في وضعية م۷إ)وم1. لا يسمح الأوراكل بحذف المجموعة اذا كان ذلك سوف يؤدي الى بقاء 
مجموعة واحدة فقط › اذ أن الأوراكل يحتاج على الأقل الى مجموعتین من مجموعات ال یذ۴ 8 .Redo‏ 
باتباع القاعدة السابقة يمكن حذف المجموعة من تعريف الأوراكل فقط > اما ملفات ال 0g‏ 0 الحقيقية 
الموجودة في الموقع المحدد (كما في المثال 43: ملف عه[ (log14.‏ لا تمسح ويجب حذفها بطريقة يدوية ' 
(كما في أوامر نظام التشغيل» في الويندوز استخدم مر مt٥1ء0).‏ 

مثال تطبيقي 4.4: 

ALTER DATABASE DROP LOGFILE GROUP 4; 

أو بذكر أسم أحد أعضاء المجموعة كما في المثال 4.3. 

يمكن أيضا تحويل حالة ال ۴|1۲ ed0 0g‏ 8R(الى‏ حالة ال هم1 بواسطة الجملة التالية: 


ALTER SYSTEM SWITCH LOGFILE; 


سوف نتطرق الى الحلات التي يمكن أن تكون عليها المجمو عة أو,العضو بعد قليل. 


:DROPPING ONLINE LOG MEMBER 


كما يمكن حذف مجموعة يمكن حذف عضو (أو أكثر) من المجموعة ولكن يجب أن يبقى على الأقل عضو فعال 
"Valid"‏ في المجموعة وإلا فإن أوراكل لن يسمح بعملية الحذف. كما في حذف المجموعة يجب أن لا يكون 
العضو هو العضو الحالي "Cunt"‏ و الملفات الفيزيائية لا تحذف من مكان تواجدها. يوجد حالة أخرى لا 
يسمح الأوراكل بحذف العضو» ذلك عندما يكون ال مووط )ه0 في حالة ال ماع ۷ ط٤٣۸‏ ولم يتم عمل 
طا للمجوعة التي ينتمى لها العضو. 


يمكن حذف عضو باتباع القاعدة التالية: 


ALTER DATABASE [database's name] 
DROP LOG MEMBER 'filename','filename',... 
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مثال تطبيقي 4.5: 


ALTER DATABASE DROP LOG MEMBER '...\oradata\db04\log4.log'; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال Cons01¢‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم و كلمة السر مع التاكد من اختيار $۷584 عوضاً عن إوإ۲ه٠..‏ 

.Storage Manager Û اضخط ع‎ 

اضغط على وم0uا6‏ و0[ 8d0‏ » ثم اختر العضو المراد حذفه واضعط على رسم سلة المهملات. 


:RENAMING LOG MEMBER 


اذا كنت تريد نقل عضو ٠٠"‏ ط٥1"‏ من موقع الى أخر أو تريد تغيير اسم العضو يجب اتباع التالي: 


اغلق ال 4e‏ طD4)4.‏ 
انسخ الملف الفيزيائي (الخاص بالعضن) الى الموقع الجديد (لنقل الملف) › أوقم بتغيير اسم الملف 
(لتغيير اسم الملف). 
قم بتشغيل ال مء ط44 في حال أل .MOUNT‏ 
اكتب الجملة التالية 
ALTER DATABASE RENAME FIEE "old Filename' TO 'newFilename';‏ 


قم بتشغيل ال مووطه)ه( وقم بعملية up‏ ه8 لل آ۴ ٥٥٤۲٠1‏ على اعتبار أن محتوياته 
تغیرت. 


:CLEARING ONLINE REDO LOG FILES 


في حال حدوث فساد للبيانات الموجودة داخل ملفات ال Log‏ 0 یمکن تنظیف الملفات باستخدام القاعدة 


التالية: 


. 
9 


ALTER DATABASE [database's name] 


CLEAR [UNARCHIVED] LOGFILE GROUP number | 'filename',... 


يمكن العدول عن عملية حذف ثم اضافة ملف ع0 8٠١0‏ بالقيام بتنظيف محتويات الملف لما توفره العملية 
من تسهيلات» اذ يمكن تنظيف مجموعة من مجموعات ال عم[ R٥٥‏ حتى ولو وجد مجموعتيين فقط 
وبداخل كل مجموعة عضو واحد فقط › ويمكن تنظيف المجموعة اذا كانت ال موو طو)د0 في حالة ال 
Archive‏ ولم يحدث عملية مi۷طءإ۸‏ للمجموعة ولكن يجب استخدام كلمة R٣) 81۷ ٤(‏ N۸]ا‏ في 


القاعدة. 
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مثال تطبيقي 4.6: 
لتنظيف مجموعة من مجموعات ال عه 8٠0‏ اكتب التالي: 
ALTER DATABASE CLEAR LOGFILE GROUP 3;‏ 


أو بذكر اسماء أعضاء المجمو عة عوضاً عن المجموعة ورقمها كما جاء سابقاً. 


:USING OMF 
التي جاء شرحها سابقاً. بواسطة ال‎ 0M۴ ينصح باستخدام ال‎ Redo Log Fes لتسهيل عملية ادارة ال‎ 
تكوين عملية تكوين مجموعة جديدة أو حذف مجموعة أسهل و يقوم الأوراكل بحذف الملفات‎ 0M ۴ 
الفيزيائية الموجودة في موقع التخزين بشكل أتوتوماتيكي عند حذف أي مجموعة.‎ 
ي‎ DB_CREATE_ONLINE_LOG_DEST_ı یجب تحدید العمل‎ « OMF لاستخدام طريقة ال‎ 
يجب‎ Redo Log Files JI عل‎ Multiplex Jلا وللقيام بعملي4‎ ]nitialization Parameter File Û 
.5 ه۴ " برقم من 1 الى‎ ۲4 ٥)٥۲" استبدال ال م في العامل‎ 
:4.7 مثال تطبيقي‎ 
یج کتابة:‎ OM ۴ لحذف مجموعة تعتمد علی نظام ال‎ 

ALTER DATABASE DROP LOGFILE GROUP 3; 
أما لإضافة مجموعة يجب كتابة:‎ 

ALTER DATABASE ADD LOGFILE; 


حيث يقوم الأوراكل بتحديد رقم المجموعة واختيار اسماء الأعضاء أوتوماتيكيا. 


للقيام بعملية ال ×م مزخ اں[M‏ يجب تحديد التالي في :Initialization Parameter File J|‏ 
DB_CREATE_ONLINE_LOG_DEST_1='...\oradata\db01"‏ 
DB_CREATE_ONLINE_LOG_DEST_2='...\oradata\db02"‏ 


DB_CREATE_ONLINE_LOG_DEST 3 ='...\oradata\db03' 
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:QUERYING LOG FILE INFORMATION 


يمكن الحصول على معلومات حول المجموعات و الأعضاء من خلال: 


V$LOG 
VSLOGFILE 


:VŞLOG 


تحتوى على بيانات حول المجموعات وأحجامها والحالة التي هي فيهاء يوجد 7 حالات يمكن أن تتواجد فيها 
المجموعهة وهم: 


10 : تدل على أن المجموعة لم تستخدم على الأطلاق في تخزين البيانات › غالبا ما يكون 
هذا النوع للمجموعات المضافة حديثاً. 

R0 في نقل بيانات ال‎ 116 ۷R تدل على المجموعة الحالية التي يستخدمها ال‎ :) UR RENT 
.Log Buffer 

.Rءء0۷ءإر تدل على أن المجموعة جاهزة لعملية ال‎ :۸ ۷٤ 

1E RNG‏ : تدل أن المجموعة في حالة تنظيف لبياناتها بعدما طلب ال 084 ذلك بواسطة 
جملة ال 5Q1.‏ التي تطرقنا لها قبل قليل وبعد ان تنظف المجموعة تتحول الحالة الى (٤Sلا0N)ل.‏ 
6EBA RING_ CURRENT‏ :دل أن المجموعة تم تنظيفها بعد طلب جملة ال اQ@؟.‏ 
:[NAC"1۷٤‏ تدل على أن أل/مء4 هه( ليس بحاجة الى المجموعة ولا تلزم في عملية ال 
Recovery‏ » وهذا هو النوع الذي (يمكن حذف. 


:VSLOGFILE 


تحتوى على بيانات حول أعضاء المجموعات. يوجد 4 حالات يكن*أن يتواجد فيها العضو وهم: 


¥0 تدل على أن ملف العضو لا يعمل. 

:S1A۸ 1٤‏ تدل على أن بيانات العضو غير مكتملة. 
PEL 50‏ : تدل على أن العضو لا يستخدم. 
فارغ ")م وا8": تدل على أن العضو يتم استخدامه. 


مثال تطبيقي 4.8: 


SELECT GROUP# , SEQUENCE#, BYTES, MEMBERS, STATUS 
FROM V$LOG; 


SELECT GROUP#F, STATUS, TYPE, MEMBER FROM V$ŞLOGFILE; 
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ARCHIVED LOG FILES 


من أهم الأمور التي يجب تحديدها من قبل ال 084 هو قرار وضع ال مءوطه٤a(‏ في وضعية ال 
 rchivelog‏ أو .Noarchivelog‏ توجد ال وواه في الحالة الأفتراضية u)"‏ هfم5"‏ في وضعية 
ال 0gاNoarchive‏ ولكن وضعية ال عه 1ء1۷ ط۸۲۲ مفيدة جداً حيث أن من فوائدها تسهيل عملية ال 
Backup‏ وتضمن استعادة "ء0۷٥8"‏ البيانات التي حدث لها اندصمصه). يمكن أن تتم عملية ال 
Archive‏ لملفات ال ع10 ل٠8‏ بطريقتيين هما: يدوية أو أوتوماتيكية والذي يتحكم بها عامل من عوامل 
.LOG_ARCHIVE_START 4 Intialazation Parameter File Û‏ 

عندما تكون قيمة ال 106G  ARCHIVE_ST ART‏ تساوي eںu٣۲‏ فان عملیة ال عہاہاط٤۸۲‏ تحدث 
بشكل آتوتوماتيكي للمجموعة الممتلئة بواسطة ال م٣۸۸‏ بعد حدوث عملية ._0g Swi‏ 

أما عندما تون قيمة ال 1_106 ۸R‏ ۷E_S1آRCH‏ ۸ تساوي Fa1[se‏ « فن عılnة Archiving J|‏ 
يجب أن تحدث بطريقة يدوية عبر استخدام جمل ال اQ؟S.‏ 


یتم تخزین بیانات في ال ۴1٥‏ 1٥٤رہ‏ اذا تمت عملیة ال عماہنط٤ ۸٣‏ بنجاح. 
يمكن القيام بعılnة Mı u[tip]ex‏ لملفات „Archived Redo Log J|‏ 
لايمكن لل ۽0 Archived Red»‏ أن تتبع نظام ال .OMF‏ 


تذکر: لا یمکن استخدام ال ٥ذ۴‏ ۽0 R46‏ "حتی تتم عملي Archiving ةılع pتıو Checkpoint Û|‏ 
للملف (هذه الحالة تحدث عندما یکون الو :٥1ع‏ 11۷ء۸۲ › إما عند حالة عم[م۷زطءإوهN‏ فقط عملية ال 
Checkpoint‏ یجلب ان تحدث). 


:QUERYING ARCHIVED REDO LOG 
.Console JI ja gi VŞINSTANCE ja Archiving JI ةılnع يمكن الحصول على بيانات حول‎ 
:4.9 مثال تطبيقي‎ 
SELECT ARCHIVER FROM VSINSTANCE; 
أو عبر ال م1مءه٥ باتباع الخطوات التالية:‎ 
.Standalone ادخل الى ال s01¢ئCon عبر‎ 
لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر.‎ Database Û اضغط على اسم‎ 
..٠هإ أدخل اسم المستخدم و كلمة السر مع التاكد من اختيار $۷584 عوضاً عن إو‎ 


اضغط على .Configuration JآذزJۓغ bخض| pû « Instance Manager Û|‏ 
اضغط على کلمة ال ر0۷6-R۸e.‏ 
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آل ہےل۔ الاس 
ملفات الداتا والتببل سبيس 


DATA FILES & TABLESPACES 


TABLESPACE 


كما عرفنا سابقاً أن ال مووطه)هD‏ تنقسم الى اوذعم_ و اهزور ط۴ بحيث تكون ال #»ومءء1طه1 هي 
أحدی مکونات ال [ھc‏ زع 0[ بالإضافة الى .Data Blocks Extents ys Segment‏ ل یمکن لل 
eمespacاbه"‏ العمل لأكثر من مووط هه( واحدة ولكن بالمقابل يمكن لل مء دمءء1طه٣‏ أن تحتوي على 
أکثر من .504)a ۴1٥‏ 

یوجد نوعان من آنواع ال 2۲م؛1 ط۲۵ هما: 


:SYSEM TABLESPACE *‏ هي ال aceمpءءاطه۲‏ التي تتكون مباشرة مع تكوين ال 
Database‏ لأنها ضرورية لعمل ال مووطو)ه0 ولا يمكن لل مووطو)هD‏ العمل بدونها. تحتوي 
على بیانات ال رھ ەtiء¡D Da)4‏ وبرامجچ ال P/Q)‏ مثل یانما 0۲۵۵)؟. تحتوي ایضاً 
عٺى ال SYSTEM UNDO SEGMENT‏ ويمكن أن تحتوي على البيانات "54)a"‏ ولکن لا 
يفضل جمع البيانات في ال ٥2م‏ ٥1ا۲۸‏ ءءر؟ بل في النوع الثاني من ال ce‏ 4مء٥1ط۾٣آ.‏ 


:NON-SYSTEM TABLESPACE‏ لإضافة مرونة على التحكم بال مووطو٤ه‏ › ينصح 
باضافة ومءءومءع[ط ه٠‏ الى ال مووطه)ه لتخزين البيانات على مختلف أنواعها. من فواند 
استعمالھا انها تقوم بفصل Application ùe < Temporary Data ùعE «< Undo Data‏ 
هط أي أنها تفصل البيانات على حسب أختلافها » ومن فوائد استعمالها ايضاً أن ال 58۸ 
يستطيع التحكم بحجم المساحة الممنوحة لكل مستخدم في ال مووطواة0. 


:CREATING TABLESPACES 
يمكن تكوين ء٥ 4مءء1طه٠ باستخدام القاعدة التالية:‎ 
CREATE TABLESPACE tablesBace's name 
[DATAFILE C1] 
[MINIMUM EXTENT numberA{K | M]] 
[BLOCKSIZE number [KI] |] 
[LOGGING | NOLOGGING] 
[DEFAULT C2] 
[ONLINE | OFFLINE] 
[PERMANENT | TEMPORARY] 
.50ءfهںuا) ملاحظة: الكلمات التي تحتها خط في القاعدة هي ال‎ 
فترمز الى جزء من القاعدة تم تخفيفه الى رموز لسهولة قراءة القاعدة:‎ ٥2 C1 أما ال الرموز ال‎ 
'filename' [SIZE number [K | M] [REUSE] | REUSE] [AUTOEXTEND ...] =C1 


STORAGE (INITIAL number K|IM NEXT number K|M =C2 
MINEXTENTS number PCTINCREASE number MAXEXTENTS number) 


سوف يأتي شرح بالتفصيل لعوامل ال €2 المبينة )... Mnifial, Nexk‏ و جaل .AUTOEXTEND Ji‏ 
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أما أوامر القاعدة فهي : 


:]MIN]|MUM EXTENT]‏ تحدد حجم جمیع ال و٤م٤×E‏ الذین ینتمون الی ال 
م وespعاطه"‏ بحيث يكون الحجم مضاعفات الرقم الموجود بجانب الجملةء يعني اذا كان الرقم هو 4 
فيكون أحجام ال و)) ×۳ مضاعفات هذا الرقم (...,16 ,8 ,4). 

DB_BLOCK _S17ZE Jalعdl لى‎ اikرعت‎ B1ock Size J| لتحديد حجم‎ :]BLOCKSIZE] 
ولكن يسمح الأوراكل بوجود أربعة أحجام أخرى لل‎ S١ ل2١ والذي يحدد الحجم المسمى بال‎ 
في حالة أن حجم ال ھل" ھt؟ لا یناسب ال‎ Non -Stan تسمى ھل‎ Block Sie 
N01- وعندئذ يمكن تحديد ال مS1 )ء810 بواسطة هذه الجملة ويكون حجم ال‎ "abاespace‎ 
.32 K8 بین 28 الى‎ Standard 

:]]0GGING]‏ تحدد أن جمیع عناصر ال ceےم1esط‏ ھ۲ من sم1ط‏ ھ٣‏ و dexesہ1‏ وغیرھا 
يجب أن يتم كتابة المتغيرات التي تطراً علیها الى ال 1ذ۴ .Redo Log‏ 

:]NOLOGGING] °‏ تحدد أن جميع عناصر Indexes yg Tables ja Tabl1espace Û|‏ 
وغيرها يجب أن لا يتم كتابة المتغيرات التي تطرأً عليها الى .Redo Log Files J|‏ 

"Storage Parameters" jيjتلا تحدد عوامل خاصة تسمى عوامل‎ :][(E۴AULT ۲٥C2] 
التي سوف نتطرق لها لاحقاً.‎ 

:]0۴۴L1NE]‏ يوجد عدد من الحالات التي یمکن أن تکون علیھا ال ٥e‏ ھم٥1‏ ط٣۲‏ بعد تكوينها 

والحالة تحدد أنها غير جاهزة للاستخدام (ضد ممام0). 

:]PERMANENT1|]‏ تحدد أن نوعية ال ءءوموءم1اط ه1 من النوع الذي يحمل بيانات دائمة. 

:]۲"EMPORARY]‏ تحدد أن آيوعية ال ء»ومءء[طه1 من النوع الذي يحمل بيانات مؤقته. 


مثال تطبيقي 5.1: 
لتكوين ال عع دمءء1ط ه1 باستخدام جملة ال 5Q1‏ يمك كتابة: 


CREATE TABLESPACE user dat 

DATAFILE '...loradata\db01\usêrdata01.dbf' SIZE 50M 
AUTOEXTEND ON NEXT 5SMZMAXSIZE 100M 

LOGGING 

OFFLINE 

TEMPORARY 

DEFAULT STORAGE (INITIAL 1M NEXT 1M MINEXTENTS 2 
PCTINCREASE 0 MAXEXTENTS 

999) 
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أو عبر ال م1موه ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال s01¢ئCon‏ عبر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم و كلمة السر مع التاكد من اختيار S۷5508۸4‏ عوضاً عن إورإه.. 

.Storage Manager J| اضغط على‎ 

اضغط على عءومءء1طه٠‏ ثم بواسطة الضغط بالزر اليمين للفأرة على ال عءےمء٥1ط ٠٣‏ تظهر 
آوامر › اختر ٥4٤٥‏ ). 

ه تظهر نافذة جديدة › ادخل البيانات المطلوبة مثل اسم ال ٥٥ے‏ م٤٥‏ 1ط ۲۸ وال ۴1٥‏ و)D4‏ التابعين 
لل 2e‏ مء 1ط ۲4 وباقي البیانات « pû‏ !ضخغط .CREATE‏ 


78 


MANAGING TABLESPACES SPACE 


عندما يتم تخصيص مساحة لأي عنصر داخل ال ٥٥ھمء٥1ط‏ ۲4 يكون لكل عنصر ٥"۲‏ عع5 تحوي على 
مجموعة من ال و٤"‏ )×5 ويمكن ادارة مساحة ال 5×٤‏ بطريقتين هما: 
Dictionary Managed Tablespaces Locally Managed Tablespace‏ 


ملاحظة: لا يمكن تغيير طريقة إدارة ال و)٥)×>E‏ بعد تحديدها. 


:LOCALLY MANAGED TABLESPACE 
تتبع ال ٥ءدمءء1ط4 هذه الطريقة عندما يتم تخزين معلومات ال و)٥)×ع في ال وء[ذ۴ و٤4 التابعة لل‎ 
۴e 810 ks يتم تخزین البیانات على شكل مه.81 (خريطة بایتات) والتي تدل علی ال‎ . "besp 
وعندا يحدث أي تعديل على ال ءء810 يقوم الأوراكل بتجديد بيانات‎ ۰5×٥٤ ءا في ال‎ B10 eks و ال‎ 

المو_ا81 لتوافق التغيرات التي طرأت. 
من فواند استخدام طريقة ال e‏ ي4ى N4‏ yااcaء0]:‏ 
تخفف الضغط على ال راو 5¡):6 .0a)4‏ 
حجم ال 5×٥٤‏ يمكن أن يقدر بشگل أوتوماتيكي و جمیع ال و٤")×E‏ تكون بنفس الحجم. 
ه عدم الحاجة الى جمع المساحات الخالية الصغيراة الضائعة التي تنشئ بين البيانات نتيجة للتغيرات 


التي تحدث وتعيد ها الى المساحة الخالية الرئيسية,وتسمى هذه العملية Coalescing Space‏ 
( بمعنى أخر أنها تمنع حدوث عمليات عديدة تسبباضغط على ال مووطو)ة0). 


لتكوين وءءدمءع1طه١‏ تتبع هذه الطريقة »> يجب اضافة الجملةءالتالية الى قاعدة 
:CREATE TABLESPACE‏ 


EXTENT MANAGEMENT LOCAL 
[AUTOALLOCATE | UNIFORM [SIZE number [KIM] ] ] 


نقاط مهمة: 
1- لا يمكن استخدام جملة ال [DEFAULT C2]‏ 
2- لا يمکن استخدام كلم .TEMPOR۸ARY JI‏ 
3 لا يمکن استخدام جمل .MINIMUM EXTENT J‏ 
أما أوامر الجملة فهي : 
U۲0 L0 TE‏ : یقوم الأوراکل بتحدید حجم ال )× ولا یستطیع ال8۸( فعل ذلك. 


.58۸ من قبل ال‎ Ex) یتم تحدید حجم ال‎ : UNIFORM 
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مثال تطبيقي 5.2 
يمكن تكوين ٠ءهمءم1ط‏ ه۲ تتبع طريقة ال كمعد" راآاهء م[ بكتابة التالي: 
CREATE TABLESPACE app_data‏ 


DATAFILE '...loradata\db01\appdata01.dbf' SIZE 250M 
EXTENT MANAGEMENT LOCAL UNIFORM SIZE 256K; 


أو اذا تم كتابة التالي فقط › فتعتبر _0ca11y M4" 2g‏ ویخذ :Autoallocate yy Default Û|‏ 


CREATE TABLESPACE app_data 
DATAFILE '...l\loradata\db01\appdata01.dbf' SIZE 250M; 


:DICTIONARY MANAGED TABLESPACE 


تتبع ال ءءدمء٥1طه۲‏ هذه الطريقة عندما/يتم تخزين معلومات ال Extents‏ في .Data Dictionary ÛJI‏ 
من فوائد استخدام طريقة ال ٥يد‏ رة رة« هذا انها توفر مرونة في تحدید حجم کل ”۸٥۲‏ ع٥5‏ على 
حده باستخدام جملة ال ٤2[‏ 11 0 ۴۸[ .كن في المقابل تلزم الحاجة الى جمع المساحات الخالية 
الصغيرة الضائعة التي تنشئ بين البيانات نتيج للتغيرات التي تحدث و تعيدها الى المساحة الخالية الرئيسية › 
أي حدوث عمليات قد تسبب مزيد من الضغط على المءوطه)ة5. 


لتكوين وءءدمءع1طه٢‏ تتبع هذه الطريقة »> يجب اضافةرالجملة التالية الى قاعدة 
:CREATE TABLESPACE‏ 


EXTENT MANAGEMENT DICTIONARY [DEFAULT C2] 
:5.3 مثال تطبيقي‎ 
CREATE TABLESPACE app_data 
DATAFILE '...loradata\db01\appdata01.dbf' SIZE 250M 


EXTENT MANAGEMENT DICTIONARY 
DEFAULT STORAGE (INITIAL 1M NEXT 1M]; 


ملاحظة: يمكن تغيير قيم العوامل ضمن الجملة [°2 011ا [D٤۴۸‏ أو جملة MINIMUM J‏ 
.Console JI رڊe gyİ « ALTER TABLESPACE رمڼJا مIخawlڊ EXTENT‏ 


80 


مثال تطبيقي 5.4: 
لتغيير جمل :Minimum Extent J|‏ 


ALTER TABLESPACE app_data MINIMUM EXTENT 2M; 


:Default Storage... J| لتغيير جمل‎ 


ALTER TABLESPACE user_data 
DEFAULT STORAGE ( 
INITIAL 2M 
NEXT 2M 
MINEXTENTS 1500); 


أو عبر ال م1امء"” ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال .Standalone رڊعe Console‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم و كلمةالسر معب التاكد من اختيار S۷5584۸4‏ عوضاً عن إورإه". 
اضغط على .Storage Manager J|‏ 

اضغط على ٥ء‏ aمء٥1ط‏ ه٠‏ ثم الضغظ بالزر اليمين للفأرة على اسم ال مء دمء٥1ط‏ ھ۲ المراد تغير 
خواصها لتظهر قائمة أوامر» أختر من الأىامر .View\Edit Details‏ 

٠ه‏ تظهر نافذة جديدة › اضغط على كلمة معدم ثم أدخل التغيرات المطلوبةء ثم اضغط رام م۸. 


تذکر: آنه لا یمکن تغییر خواص ال ٥ع۲4٥)؟‏ لل 4٥‏ مع1ط ٢۸‏ التي تتبع طريقة ال M42 ge‏ yاا0caا.‏ 
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NON-SYSTEM TABLESPACES 


يوجد أكثر من كم دمءء1طه٣‏ «mءاءرS-«هN‏ ولكل منها وظائف مختلفة في ال مووطه)ه › منها 
.Temporary Tablespace s Undo Tablespace y Permanent Tablespace‏ 

أما Permanent r ablesp ace‏ فوظائفها تخزین البيانات ") 51" لفصل بیانات ال eءھ‏ 4٤ھ‏ عن 
بيانات ال راه« ٠ء1‏ واه( و لسهولة التحكم في البيانات بحيث اذا تم حذف ال مءومءم1ط 14 الخاص 
بها لا يؤثر ذلك علی عمل ال رہ)1 و( و لتخفیف الضغط علی ال ceے System ٣1٥p‏ وال 
atabAseط‏ بشكل عام. 


:UNDO TABLESPACE 


تستخدم لحفظ ال ۲٠ص‏ عهS‏ 0ل 11ا ولا يمكن أن تحتوي على غيرها. يتم إدارة ال و٤٥)×E‏ بطريقة ال 
Managed‏ yاا0ca.ا‏ و يمكن تكوينها باتباع القاعدة التاليه (أو تكوينها عند تكوين ال #ءsوطه)ة5‏ 
ڊlتخد|م :(CREATE DATABASE‏ 


CREATE UNDO TABLESPACE tablespace name 
[DATAFILE C1] 

EXTENT MANAGEMENT LOCAL 

[AUTOALLOCATE | UNIFORM [SIZE number{K|M] ] ] 


ملاحظة: تستخدم Undo Tablespace Jl‏ في ال ئ ۸ıt0omatic Undo Managenîen‏ التي سوف 
نتطرق لها في فصل أخر مع ال Seg ٤۲‏ d0ہ0ا.‏ 


مثال تطبيقي 5.5: 


CREATEUNDO TABLESPACE undo01 
DATAFILE '...loradata\db01\undo101.dbf' SIZE 50M; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال Console‏ عڊر .Standalone‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار $S۷¥5S584‏ عوضاً عن إومإه.. 

.Storage Manager Û Jlع |ضخط‎ 

اضغط علی ٥٥ے‏ موم1ط ه۲ ثم الضغط بالزر الیمین للفأرة علی اسم ال c۲‏ 2م5٥‏ 1ط ٣۹‏ المراد تغير 
خواصها لتظهر قائمة أوامر» أختر من الأوامر مtو٠إ).‏ 

٠‏ تظهر نافذة جديدة » أختر ملم ا عوضÎ‏ عjù Permanent‏ ثم ادخل البيانات المطلوبة مثل اسم ال 
pî Tablespace‏ ضط .Create‏ 


JI و‎ Alert Log File JI g Control File J| تخزن في‎ €n d0 Seg men) تذکر: بیانات ال‎ 
.Initialization Parameter File 
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:TEMPORARY TABLESPACE 


توفر المساحة اللازمة لعمليات ال 50٤‏ المختلفة الناتجة عن أوامرعدة مثل ر8 .Group Byوأ 0dr‏ 
بمعنى أخر أنها تخزن البيانات المؤقتة ٥0 4)a"‏ 02۲م ص٥۲"‏ وتحوي ما یعرف ڊ Sort Segment‏ 
والتي تتکون في ال ٥٥م‏ ء٥1‏ ط۲1 عند أول عملية $0٤‏ تطلب من ال ce‏ ھtوہ[.‏ یمکن إدارة ال و٤ر٤)Ex‏ 
بالطريقتين و لکن ينصح باستخدام ._0c211y M4 "4g‏ 


ملاحظة: تستطيع ال ٠١۲‏ _عءع$ 50۲۲ التوسع في المساحة بحجز المزيد من ال E×)٥"٤s‏ لكي يتم تغطية 
المساحة اللازمة لعمليات ال 50۲ المختلفة. 


يمکن تکوين CREATE TABLESP ACE ةlaج pIدختlب Temporary Ta ۆ1espace Û|‏ مع إضافة 
كلمة "EM P0١R ۸R‏ في الجملة و لكن يفضل استخدام القاعدة التالية لتكوين e‏ ع4 Ma"‏ yاا0ca[:‏ 


CREATE TEMPORARY TABLESPACE temp's name 
TEMPFILE 'filename' 

EXTENT MANAGEMENT LOCAL 

[AUTOALLOCATE | UNIFORM [SIZE number [K|M] ] | 


مثال تطبيقي 5.6: 


CREATE TEMPORARY TABLESPACE temp01 
TEMPFILE '...\oradata\db05\ternrîp01.dbf ' SIZE 200M 
EXTENT MANAGEMENT LOCAL UNIFORM SIZE 10M; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال Console‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار Ş584؟S۷‏ عوضاً عن إوصرإه.. 

.Storage Manager J| اضغط عل‎ 

اضغط على ٥٥‏ 4مءع1ط ه٢‏ ثم بواسطة الضغط بالزر اليمين للفأرة على ال ٣4 ط1٥ءمے ce‏ تظهر 

آوامر › اختر .٤°٥4)٥‏ 

٠‏ تظهر نافذة جديدة › أختر الخیار رإ مم٥۲‏ عوضاً عن ٤٤م‏ ھ ۴٥٣.‏ ثم ادخل البیانات 
المطلوبة مثل اسم ال ءءومءء1طه١‏ و أدخل البيانات التابعة لقسم ال معوإه)S‏ مثل ال مذS.‏ 

٠ه‏ ثم أضغط م٤وءإC٤.‏ 


يعتبر "EMPFILE‏ (الذي استخدم في القاعدة) متطابقاً لل ٤۳۴ا A۴]‏ عدا في الاختلافات التالية: 


لا يمكن وضعه في حالة القراءة فقط yرار0-4dءR۸.‏ 

لا يمكن تغيير اسم الملف. 

لا یمکن أن يتم له عملیة را .R۸-0۷‏ 

لا يمکن تكوين4 بlستخدIم .ALTER DATABASE ÛJI‏ 
دائماً في وضعية ال .NO_L0١0GG1۸N6G‏ 

.CREATE CONTROLFILE JI ةlaج‎ g لا يمکن استخدامھا‎ 
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:Default Temporary Tablespaces 


lتخدIم‏ قlعدö hefault Temporary Tablespace ùıgكت jas CREATE DATABASE‏ والتي 
تحمي ال میوط هه( من استخدام ال ce‏ 2م ٥1ا۲4 System‏ عوضاً عن ال راهم ۲٥"‏ في تنفیذ 
عمليات ال 50٤s‏ والتي قد تؤدي الى مشاكل عدة في ال مءومءء[ط14 "٠٤ءر؟‏ وازدياد نسبة ال 
.System Tablespace Û Jl Fragmentation‏ 

في حال لم یتم تکوین ال ce‏ 2م empor ary ٦2ا1 es‏ ۲آ مع تکوین ال 46 ط)4( وتم تکوینها بعد ذلك › 
يمکن تحدید Default Temporary Û li‏ بواسطة مر ALTER DATABASE‏ وجمیع 

المستخدمین الذین کانوا یستخدمون ال ce‏ ھم٤٥‏ [ط ھ۲ ٥٥٣‏ )ءر؟ لعملیات ال ۶٤ہ‏ یتم تحویلھم بشكل 
أوتوماتيكي ا .Default Temporary Tab1espace Û|‏ 


ملاحظة: اذا اراد DBA JI‏ تير Temporary gl Default Temporary Taۆblespace JI‏ 
ce‏ espaاb‏ هآ اخرى لتکون هي ال )ا ۾fء‏ 5 « يمک استخدIام .ALTER DATABASE‏ 


CREATE طwlgڊ‎ Default Temporary Taۆb1espace‎ Û| ùيyكت ملاحظة2: اذا تم‎ 
.L0ca211y M4 2g ¢ فإنھا تتبع طریقة ال‎ D1 ۸ BASE 


:Default Temporary Tablespace قیود ال‎ 


Temporary yl llgحت بعد‎ ¥! Default Temporary4Eab1espace J| لا يمكن حذف‎ 
.ALTER D۸T۸AB4ASE'Il#Aطwسlgڊ أخر‎ Tablespace 


.Permanent yil Defailt Temporary Û Jيوحت لا يمکن‎ 


ه لا يمكن وضعها في حالة ال ممذا؟؟0. 


مثال تطبيقي 5.7: 


لتعریف ال ceھم1espط‏ ھ٣ rem porary‏ کنوعیة ال ٤اںuھfمD‏ أو لتغییر ال رھم ۲e‏ {اDefau‏ الی 
أخری يجب كتابة التالي: 


ALTER DATABASE DEFAULT TEMPORARY TABLESPACE temp02; 
باتباع الخطوات التالية:‎ ٥٠ أو عبر ال م1مو"‎ 


ادخل الى اÛ Console‏ عڊڙر „Standalone‏ 

اضغط على اسم ال مووطه)ه( لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S584؟S۷¥‏ عوضاً عن إومإه.. 

.Storage Manager J| اضخط ع‎ 

اضغط على عءومء٥1طه٠‏ ثم بواسطة الضغط بالزر اليمين للفأرة على ال ع ےمء٥1ط ٠٣‏ تظهر 

آوامر › اختر ع٥)4٥۲).‏ 

٠‏ تظهر نافذة جديدة › أختر الخیار yرإ‏ مم٥۲‏ عوضاً عن ٤٤م‏ ھ ص٣٥۴‏ ثم ادخل البیانات 
المطلوبة مثل اسم ال ءءومءم1ط ه٠‏ وأدخل البيانات التابعة لقسم ال #عوإهمSt‏ مثل ال م1z؟.‏ 

.Create ضط‎ pû Set as Default Temporary Tablespace ill يجت تحږديد‎ ٠ 
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ALTERING A TABLESPACE 


یمکن تعدیل 6۶ے مءع1ط ۲۸ أو حذفهم بواسطة أمر ۸L۲ ER "A BLESPACE‏ بحیث یمکن تنفیذ 
بواسطة هذا الأمر: تغيير الحالة بين ممذا؟؟0 و ٭ء«نام0 › وضع ال مءومءء1ط ه٣‏ في وضعية القراءة فقط 
Read-Only‏ › حذف ce‏ aمspم1‏ اھ۲ › تغییر حجم ال مم1 ط۰۲4 وغیرها من المهام. 


:OFFLINE OR ONLINE 


عندما تکون ال Tablespace‏ في حالة Y' «Offline‏ يستطیع المستخدم استخراج البيانات المخزنة في ال 
Tablespace‏ من ال e‏ طata(.‏ یمکن وضع ال ceےمb1e ۲a‏ في حالة ال مءمذا؟؟0 لعدة اسباب منها أن 
ال D8۸‏ يرغب في اغلاق جزء من البيانات أو عمل عملية up‏ )ه8 أو رإء۷٠ء٠8‏ على هذا الجزء دون 
اغلاق ال موه طه)هD‏ بشکل تام أو نقل أو تغییر اسم ی٥۴1 4٤a‏ لل ceےمءم1ط‏ ھ۲ دون إغلاق ال 
8t4‏ بشکل کامل. 

عندما تتغير حالة ال #عومء٥1طه١‏ من ء«نام0 الى م«ذا؟؟0 أو بالعكس» يتم تخزين معلومات حول العملية 
في Tablespace JI ll Jugحت [stance Jl jn .Contro1 File J| „ês Data Dictionary Û|‏ 
بين الحالتين عند حدوث أخطاء أو مشاكل مثل عدم المقدرة على نقل البيانات الى ال مومءءاطه1. 

لا يمكن وضع جميع ال وھ مء٥1ط‏ ه۲ في/حالة ال 0۴Ên‏ اذ يسثنى کل من System Taۆ1espace Û|‏ 
Default Temporary Û‏ وال ê¢espaاb ra‏ التي تحوي Undo Segment‏ في حالة .Active‏ 


يمكن التحويل بين الحالتين باستخدام القاعدة لتالية: 


ALTER TABLESPACE tablespace's nãme 
ONLINE | 
OFFLINE [NORMAL | TEMPORARY | IMMEDIATE| FOR RECOVER] 


أوامر القاعدة: 


Data Files JIب الخاصة‎ "Dirty Bu ffمrء'" يتم كتابة جميع البيانات المتغيرة‎ : NORMAL 
ضمن ال 4م٥1 ط۲۸ المراد إغلاقها.‎ 5٤4 ۴16s في ذاکرة ال 96۸ الی ال‎ 
ضمن ال‎ 0nاine‎ Data ۴ ¡1es لجمیع ال‎ Check poi توفر عملیة‎ : TEMPORARY 
.Offline Data Files JÛ المراد إغلاقها و لا توفر ذات العملية‎ ra bاespace‎ 
Tablespace JI jaض¦‎ Data Files JI ıJ Checkpoint لا تقوم بعملية‎ :]MMEDI[ATE 
.0واiمم المراد غلقها وبالتالي يجب القيام بعملية رإ ء۷٠٠٠۸ عند الرغبة بتحويلها الى‎ 
.Rec0very ا۲4 في عملیة‎ 1esp2 ce لاستخدام ال‎ :FOR RECOVER 


تذکر النقاط التالية: 


Temporary JÎ Permanent Taۆ1espace‎ J| يعمل عندما يتم وضع‎ DBW n أن اڵ‎ 
.Offline ÛJI lla „ê Tablespace 


ه٠‏ أن وضع ال ءءومءء[ط ه۲ في حالة ال ادرإه ء«نا؟؟0 يؤدي الى حدوث عملية ال 
.Checkpoint‏ 


ه أنه يمكن وضع ال م4 مءء1طه٣‏ في احدى الحالتين عند تكgيli‏ بوulطة CREATE‏ 
.TABLESPACE‏ 
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مثال تطبيقي 5.8: 
لوضع ال #ء4مءء1ط۲4 في حالة ال م«ذامو0 يجب كتابة: 


ALTER TABLESPACE user_data ONLINE; 


لوضع ال #ءومءء1طه١‏ في حالة ال ٠«ذا؟؟0‏ يمكن كتابة: 
ALTER TABLESPACE user_data OFFLINE;‏ 
ALTER TABLESPACE user_data OFFLINE IMMEDIATE;‏ 


ALTER TABLESPACE user_data OFFLINE TEMPORARY; 


أو عبر ال م1امء"”هC‏ باتباع الخطوات التالية: 


ادخل الى ال C001‏ عیبر .Standalone‏ 

اضغط على اسم ال ماه( لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر معآالتاكد من اختيار S۷584‏ عوضاً عن إوصإه.. 
اضغط على .Storage Manager J|‏ 

اضغط على ال + بجانب كلمة ءءومم1طه1 ليظهر قائمة بأسماء ال ومومءاطه1. 

اضغط علی اسم ال ٥٥‏ 2م٥1‏ ط ه۲ المراد.تحويل حالتها. 

يظهر على النافذة الیمنی بعض خصائص ال م26م٥1ط ٠١٠‏ اختر م,ذا؟؟0 وحالة الإغلاق من 
المجموعة التي بجانبها ثم اضغط على رام م ۸؛ 


:READ-ONLY TABLESPACE 


يمكن وضع ال عءومءء[ط ه1 في حالة القراءة فقط "'رام "۸8٥43-0‏ اذا رغب ال D8۸‏ بأن تتم قراءة 
بیانات ال وم۴1 و)04 ضمن ال ٥م٥1‏ ط۲۹ دون تغییر البیانات. لکي یستطیع ال 8۸4( وضع ال 
espaceاb ra‏ في حالة ال رارRe4۵-0‏ یجب أن یکون جمیع ال ۴1٥s‏ واھ( التابعیین لل ceےb1epھ۲آ‏ 
في وضعية ما0 وإلا فأن العملية لن تنجح › والعكس صحيح في حال تحويل ال #ءومءء1اطه1 من 
yا0n-ل Rea‏ الى الحالة العادية Wr¡†e-44ءRe‏ يحب توفر جميع ال و۴16 )04 في وضعية eمiام0.‏ 
يمكن وضع ال #ءدمءء1[طه١‏ في حالة رام4-0 ه٠8‏ باستخدام القاعدة التالية: 


ALTER TABLESPACE tablespace's name READ [ONLY | WRITE] 
اذ أن حذف عناصر لا تکون‎ Read-Only ab espace من ال‎ )٣ھ‎ 16s, يمکن حذف عناصر (ءع×ع لہ[‎ 
.04)a (ان٠ بيانات جديدة في ال مء ومءه[ط ه۲ ولا تغيير البيانات الموجودة إنما تغيير بيانات ال رإو‎ 
وفي حال كانت تجرى على ال عcومء٥[طه۲ عدد من المهام "٠0إاءدورهإآ" عند عملية التحويل › يتم‎ 
منع حدوث مهام جديدة ويتم انجاز المهام التي تجري وإما أن تسجل البيانات الناتجة عن المهام عند حدوث‎ 
.R‌ها11!طھ) أو تلغی عند حدوث‎ Commit 


ملاحظة: لا يمكن وضع ال ace‏ مء٥1ط۲4‏ صmءtءرS‏ في حالة ال .Read-Only‏ 
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مثال تطبيقي 5.9: 
لوضع ال م4مءع1طه٣‏ في حالة ال رام434-0٠8R‏ يجب كتابة: 

ALTER TABLESPACE user_data READ ONLY; 
لوضع ال عمءدمءء[طه1 في الحالة العادية:‎ 

ALTER TABLESPACE user data READ WRITE; 
أو عبر ال #امودهC باتباع الخطوات التالية:‎ 


ادخل الى ال „Standalone رjڊع Console‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S¥9S584‏ عوضاً عن إومإه.. 
اضخط ع .Storage Manager J|‏ 

اضغط على ال + بجانب كلمة مءومءء[طه1 ليظهر قائمة بأسماء ال ومومءءاطه1. 

اضغط على اسم ال c٥‏ 2م٥1‏ ط۸٠‏ المراد تحويل حالتها. 

يظهر على النافذة اليمنى بعض خصائص ال مء دمءء1طاه1» ضع علامة في المربع بجانب كلمة 
Read Only‏ » تم اضغط على_رآاممA.‏ 


تذكر: أن وضع ال مءومءم1ط ه٠‏ في حالة ال ”راآً4-0هءR‏ يؤدي الى عمل ال (8W‏ و حدوث عملية ال 
.Checkpoint‏ 


:DROPPING TABLESPACES 
يمكن حذف ء٥4مءء1طه٣ من ال 44#وطه)ه0 باستخدام القاعدة التالية:‎ 


DROP TABLESPACE tablespace's name 
[INCLUDING CONTENTS [AND DATAFILES] [CASCADE CONSTRAINTS]] 


أوامر القاعدة: 


:I[NCLUDING CONTENTS °‏ اذا كانت ال e‏ 4م1s‏ 14 خالية لا تحوي أي بيانات 
"واه" فلا يشترط كتابة هذه الجملة › ولكن اذا كانت تحوي على بيانات "و٤54"‏ فيجب كتابة 
هذه الجملة. 

AND DATAFILES °‏ : کما تعرف أن لکل ۲٥ھ‏ موع1ط ۲۹ مجموعة من ال ]ذ۴ هه التابعة 
لها تكون الجزء الفيزيائي (الملفات الحقيقة) على موقع التخزين (مثل القرص الصلب). عندما لا 
تكتب هذه الجملة لا تحذف ملفات ال وا۴ ه)04 من موقع التخزين والعكس صحيح اذ أن كتابة 
هذه الجملة تؤدي الى حذف ملفات ال وم۴ و)ه( بشكل أوتوماتيكي. 

:)AS ADE CONSTRAINTS‏ يجب استخدام هذه الجملة في حالة وجود ما يعرف ب 
)F۴oreign Key) Referential Integrity‏ من ۲a 1e‏ توجد خارج ال ce‏ مspع1ط‏ ھ٣‏ المراد 
حذفھا مغ Primary Key‏ أو "abe Unique Key‏ موجودة داخل ال ce‏ 2م٥1‏ ط۲4. في حال 
وجود هذا الرابط ولم يتم استخدام هذه الجملة › تفشل عملية الحذف. 
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نقاط مهمة: 
1- یمکن حذف ال ٥‏ ھمءم1ط ه٣‏ التي توجد في وضعية رار0-0ل4ءR۸.‏ 


2- ينصح بتحویل ال ٥٥‏ ےم٥1ط‏ ۲۵ الى حالة 1«۲ا؟0۴ قبل حذفها للتأكد من عدم وجود مهام أو عمليات _ 
تجري على ال مء ومءم1[ط ه۲ » اذ بتحويلها الى ء«ذا؟؟0 يتم وقف العمليات الجديدة وإنهاء المهمات الحالية 


3- بعد حذف ال ٥٤ے‏ مءم1ط ھ۲ یتم تعدیل بیانات ال ۴1۲ 1٠إ٤"ه)‏ لتتوافق مع التغيير الذي حدث في ال 
.Tablespace‏ 


تذکر: أن ال ۴1٥‏ 1٥۲٤«ه)‏ يحوي معلومات حول أسماء ال وم وموءم1طه1 وأسماء و مواقع ال و٤54‏ 
.Files‏ 


مثال تطبيقي 5.10 
لحذف ع٥‏ ومء٥[طه‏ يمكن كتابة التالي: 


DROP TABLESPACE sêr data 
INCLUDING CONTENTS ANDDATAFILES; 


DROP TABLESPACE user _ data 
INCLUDING CONTENTS.CASCADE CONSTRAINT; 


DROP'TABLESPACE user_ data 
INCLUDING CONTENTS AND DATAFILES CASCADE CONSTRAINT; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال .Standalone رڙڊe Console‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السس. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷5784۸4‏ عوضاً عن إوصإه.. 
اضغخط على .Storage Manager JI‏ 

اضغط على ال + بجانب كلمة مءومءم[ط ه1 ليظهر قائمة بأسماء ال ومعومءء[اطه1. 
اضغط على اسم ال 1٥۲‏ م٥1ط‏ ه۲ المراد حذفها. 

استخدم الزر اليمين للفأرة اتظهر لك قائمةء اختر 0e‏ ءR۸.‏ 

أختر وم۷ لتأكيد الحذف. 
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:RESIZING A TABLESPACE 


یمکن زیادة حجم ال ٥‏ ےمءع[ط ۲۸ بزیادة حجم ال و۴1 وه( التابعة لها أو إضافة وم۴1 و٤4(‏ جديدة لل 
ce‏ espaاab".‏ یمکن زیادة حجم ال وم۴ و٤4(‏ بطريقة يدوية أو أوتوماتيكية. 


:Automatic Extension 


یمکن استخدام جملة ال ۲6۵ ٤×‏ ۸10۲0 لزيادة حجم ال و۴16 (4a‏ بطريقة أوتوماتيكية أو لوقف هذه 
العملية. يمكن استخدام جملۂ ال ٤×X 1END‏ 10 ۸€ بعد تكوين Tablespace Û! yi Database J|‏ 
باستخدام القاعدة التالية: 


ALTER DATABASE [database's name] 

DATAFILE 'filename' [SIZE number] [K | M] [REUSE] 
[AUTOEXTEND OFF|ON [NEXT number [K|M]] 
[MAXSIZE UNLIMITED | number [K |M]] 


أوامر القاعدة: 


U" 0 EXTEND OFF‏ : توقف عملية زيادة حجم الملفات بشكل أوتوماتيكي. 

U۲" 0 EXTEND ON °‏ ۸:-لتشغيل عملية زيادة حجم الملفات بشكل أوتوماتيكي عند أمتلاء 
الملفات. 

.Data Fi] e§JلI£اڻلتمأ حجم الزيادة عند‎ : NEX ۲ 

:MN AXE‏ لتحديد الحجم الأقصئ الذي یمکن أن يصل له حجم ال وم۴1 وا04. يمكن أن يحدد 
الحد الأقصی أو ان يكون غير محدد باستخڈام .U N11۷7 ٤‏ 


CREATE s CREATE DATABASE 5 في اعد‎ ۸U10٤×X 1END تذكر: تستخدم جملة ال‎ 
.TABLESPACE 


مثال تطبيقي 5.11 
لزیادة حجم ال ۴116s‏ و٤04‏ ضمن ال 2٥٥‏ مءء1ط4٠‏ بشكل أوتوماتيكي: 


ALTER DATABASE DATAFILE '...l\loradata\db01\userdata01.dbf 
AUTOEXTEND ON NEXT 10M MAXSIZE 250M; 


أو عبر ال م1امء"”ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال C001‏ عیر .Standalone‏ 

اضغط على اسم ال #ءطهه( لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 S۷50‏ عوضاً عن إوصإه.. 

.Storage Manager J| اضغط عل‎ 

اضغط على ال + بجانب كلمة یم۴1 وو( ليظهر قائمة بأسماء ال ا۴ و04. 

اضغط علی اسم ال ۴1۲ و٤(‏ المراد تكبیرھا. 

اضغط على كلمة ال ءعوإه)؟ لتدخل الى القسم الأخر . 

ضع علامة في المربع ثم أکتب قم Unlimited laإ رتخاy « Increment (NEXT) ja J‏ او 
قیمة e‏ ں۷41 ثم اضغط على رامم۸. 
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:Manual Extension 
يمكن زيادة أو انقاص حجم ال و٥[۴ و٤4( باستخدام القاعدة التالية:‎ 


ALTER DATABASE [database's name] DATAFILE 'filename', ['filename?2'] ... 
RESIZE number [K|M] 


سؤال: لنفرض أنه یوجد لدینا ۴11۲ )04 حجمه M18‏ 100 وهو يحوي علی 18 70 بیانات › واراد ال 
B4‏ تصغیر حجمه الى M18‏ 60 › فهل تنجح العملية ؟ و کم یکون حجم ال 046a ۴1٥‏ بعد التصغير؟ 


جواب: نعم تنجح عملية التصغير ولکن یکون حجم ال ۴۲ )ه0 هو حجم البيانات فيه وهر M18‏ 70. 
ملاحظة: يمكن تكبير أو تصغير حجم أكثر من ملف في نفس الوقت كما في المثال 5.12 

مثال تطبيقي 5.12 

لزیادة حجم ال ی۴16 a)ے0‏ ضمن ال ٥٥ھ‏ مءء1ط۲4 بشکل يدوي : 


ALTER DATABASE DATAFILE '...\oradata\db01\userdata01.dbf', 
'....loradata\db01\userdata02.dbf’ 
RESIZE 250M; 


أو عبر ال 01ء٠٥‏ باتباع الخطوات التالية: 


ادخل الى ال „Standalone رڊۈe Console‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷958‏ عوضاً عن إوصإه.. 
اضغخط على .Storage Manager J|‏ 

اضغط علی ال + بجانب کلمة و٥[۴‏ وھ( لیظھر قائمة/بأسماء ال وم۴ 04)4. 
اضغط على اسم ال ۴11۲ (4a‏ المراد تكبيرها أو تصغيرها. 

ادخل الحجم الجديد في خانة ٣۴[٥ S1۵‏ ثم اضغط رامم۸. 
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:Adding Data File 
يمكن اضافة وم۴1 و٤0 الى ال معومءء[طه٣ لتكبير حجمها عبر القاعدة:‎ 


ALTER TABLESPACE tablespace's name ADD DATAFILE 
"filename" [SIZE number [K|M]] [REUSE] [AUTOEXTEND ...],.... 


ملاحظة: يمكن اضافة أكثر من ملف في نفس الوقت. استخدم فاصلة في أخر القاعدة وأعد كتابة السطر الثاني. 
كما في المثال 5.13. 


مثال تطبيقي 5.13: 


:Tablespace ÛI Jl Data Files ةİlضlل‎ 


ALTER TABLESPACE user _ data ADD DATAFILE 
'...loradata\db01\userdata01.dbf' SIZE 200M 
AUTOEXTEND ON NEXT 10M MAXSIZE 250M, 
'...loradata\db01\userdata02.dbf' SIZE 200M 
AUTOEXTEND ON NEXT 10M MAXSIZE 250M; 


أو عبر ال م1مء"٠C‏ باتباع الخطوات التالية: 


ادخل الى ال ٤C٥ 1401e‏ عبر ¢ م .Staı dao‏ 

اضغط على اسم Database Û|‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من آختيار S(584؟S۷‏ عوضاً عن إوصرإه.. 
اضغط عل .Storage Manager J|‏ 

اضغط على ال + بجانب كلمة مء وموءع[ط ه٢‏ ليظهر قانة بأسماء ال ومعومءءاطه1. 
اضغط علی اسم ال c٥‏ ےمیع1ط ھ۲ المراد اضافة ١ا۴‏ واو لها. 

استخدم الزر اليمين للفأرة اتظهر لك قائمةء› ءان؟ه)0a(‏ 4لA.‏ 

تظهر لك نافذة جديدة › ادخل البيانات مثل اسم الملف ثم اضغط ع٤4٠)°.‏ 


:MOVING DATAFILES 
ALTER gy ALTER TABLESPACE lal مIدختسlڊ ۾)54 من موقع الى خر‎ ۴1٥s یمکن نقل ال‎ 
.DATABASE 


باستخدام :Alter Tablesp ace‏ 
يمكن نقل ملفات ال ءز۴ و٤(‏ باستخدام القاعدة التالية: 
ALTER TABLESPACE tablespace's name‏ 


RENAME DATAFILE 'filename' , ['filename'] 
TO 'filename' , ['filename']; 


91 


ربق التق 


.Offline ll في‎ ١a1 esp ace ضع ال‎ 

نسخ ملف ال ٥1ز۴‏ واه الى المواقع الجديدة (القيام بعملية النسخ كما في نظام التشغيل › اي في 
الويندوز يستخدم llفİزة „PASTE ys COPY ga‏ 

تنفيذ القاعدة السابقة. 

تحویل ال ce‏ 4 مءع1ط "a‏ الى Ûlئllة Online‏ 

يمكن حذف ال ١ء۴‏ ه)4( الموجودة في الموقع القديم كما في نظام التشغيل. 


شروط الاستخدام: 


يجب أن تكون ال #ءومءء[ط ه۲ في حالة اÛ .Offline‏ 

يجب تواجد ملفات ال وء[ذ۴ )د( المراد نقلها في الموقع المحدد في القاعدة. 

يجب أن تتطابق اسماء ال و۴6 a)ه0‏ المنقولة مع اسماء ال وماز۴ وه المخزنة في ال 
.Control File‏ 

لا یمکن نقل ی٥۴1‏ وھ( التابعیین لل .System Taۆ1esp ace‏ 


مثال تطبيقي 5.14: 


بعد تنفيذ النقطتين الأولى و الثانية من طركقة(النتفيذ: 


ALTER TABLESPACE app_data RENAME DATAFILE 
'...loradata\db01\app01.dbf®'...loradata\db01\app02.dbf" 
TO 
'...loradata\db02\app01.dbf' , ' ...loradata\db02\app02.dbf'; 


:Alter Database مIدختسlب‎ 


یمکن نقل ملفات ال و۴1۲ و٤(‏ باستخدام القاعدة التالية: 


ALTER DATABASE database's name 
RENAME FILE 'filename' , ['filename'] 
TO "filename" , ['filename']; 


طريقة التنفيذ: 


اغلاق ال eھطD4)4.‏ 

نسخ ملف ال ۴1۲ 0a‏ الى المواقع الجديدة (القيام بعملية النسخ كما في نظام التشغيل › أي في 
الويندوز يستخدم الفأرة „(PASTE ڍy COPY ga‏ 

تشغيل ال موو ط واه( في حالة اÛ .Mount‏ 

تنفيذ القاعدة السابقة. 

تشغيل ال موو طهاه0 في حالة «ء0p.‏ 
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شروط الاستخدام: 
ه يجب أن تكون ال مووطه)ه0 في حالة ال .Mou n)‏ 


ه يجب تواجد ملفات ال و٥آ۴ (a‏ المراد نقلها في الموقع المحدد في القاعدة. 
یمکن نقل ۴٥‏ وھ التابعیین لٰل lespaceۆTa .System‏ 


تذكر: هي نفس القاعدة التي استخدمناها لنقل أو تغيير اسماء .Redo Log Files JI‏ 


مثال تطبيقي 5.15: 
بعد تنفيذ الثلاث نقاط الأولى من طريقة النتفيذ: 
ALTER DATABASE app_data RENAME FILE‏ 
'...loradata\db01\app01.dbf"‏ 


TO 
'...loradata\db02\app01.dbf'; 


:TABLESPACE WITH OMF 
"Parameter" بتحد<العامل‎ M۴ تتبع نظام ال‎ ۲۹ ط1٥٤م‎ 4٥٥ یمکن تکوین‎ 
واستخدام قاعدة ال‎ Taۆblespace‎ Ji نیيعبlill‎ Data Files Ji DB_CREATE_ FILE _ DEST 
مع عدة اختلافات مثل عم الضزیرة لذکر اسم ال ی٥۴ و04 في‎ CREATE TABLESPACE 
القاعدة,‎ 
CREATE TABLESPACE tablespace's name 
[DATAFILE [filename] [SIZE number [K|M] ] ; 
:Data Files J| تکون‎ 0M ط۲۹ بنظام ال‎ 1٥٤م‎ 2٥e عند تکوین ال‎ 
)5.16 (کما في المثال‎ 100MB Defauاt حجمھا ال‎ 
مع عدم تحديد أقصى حد‎ )۸110٤×1۴[( ه تستخدم الطريقة الأوتوماتيكية لزيادة حجمها‎ 
.(UNLIMITED) مجحلJ‎ 
:5.16 مثال تطبيقي‎ 


لتکوین 1٥٥‏ م٥‏ 1 ط۲۸ بنظام ال 0M۴‏ یجب تحدید العامل "Para mete"‏ 
DB_CREATE_FILE_DEST‏ ثم كتابة التالي: 


CREATE TABLESPACE new_data; 
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:QUERYING INFORMATION 
يمكن استخدام:‎ ٠4 للحصول على معلومات حول ال وء دمءء1ط‎ 
مم1 ط۲4 في‎ 4٥6s یوفر هذا ال س۷1 معلومات حول جمیع ال‎ :DBA_"ABLESPACES 
(Temporary, Undo) Tablespace JI Ãyعgis‎ Tablespaces J| اسم‎ Jûa Database J| 
وغیرھا.‎ )[0caا1اy,‎ Dictiە‎ "4 y( E×)ء‎ "٤s ونو عية ادارة ال‎ 


ŞA BLESPACE *‏ : توفر معلومات عن اسم و رقم ال 6s‏ ھم٥[طا۲۵.‏ 


للحصول علی معلومات حول ال و٥۴‏ 4)4( یمکن استخدام: 


:D(BA_DA1A_FILES *‏ یوفر معلومات حول ال ۴۶ Data‏ مثل اسم D٤4 ۴٥۶‏ وال 
espaceاbه"‏ التي ينتمي لها ال ۴1۲ )0 وحجم ال وم۴ و)( وغيرها من المعلومات. 


Data File JI ll Jû Data Files يوفر معلومات حول ال‎ :YŞDATAFILE 
وغیرها.‎ 54)a حجم ال م۴1‎ › )0nاine,‎ 8 line) 
للحصول على معلومات حول ال ۴1ص51 يمکن استخدام:‎ 


:DBA_TEMP_FILES °‏ يور منڭلومات حول Jûa Temp Files JI‏ اص Temp Files‏ و JI‏ 
espaceاbه"‏ التي ینتمي لھا ال ۴1۲ م ,ء۲ وحجم ال وم۴ م 1٥,‏ وغیرها من المعلومات. 


Temp File JI Ãll Jûa Temp Fileۆ‎ Ù يوفر معلومات حول‎ :YŞTEMPFILE 
وغیرها.‎ emp ۴¡1es حجم ال‎ › )Onاine,0‎ 8 fline) 
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الول الس امس 
السيجمنت و خصانص التخزين 


SEGMENYS & STORAGE 
STRUCTURES 


SEGMENTS 


ال ٤مصعهS‏ هي احدی مکونات ال Structure‏ 0gica1ا‏ وتأتي بعد ال 6٥ے‏ ص٥1ط‏ ۲4 في الترتيب › 
یمکن لل م٥4‏ مءم1ط ه۲ أن تحوي آکثر من ٤٣ط‏ عم کما یمکن لل "٥۸۲‏ ع٥5‏ أن تتکون من آکثر من 
.Extent‏ 


يوجد عدة أنواع من ال ۸۲٤إعم$‏ مثل: 


.TABLE SEGMENT 

.TABLE PARTITION SEGMENT 

. CLUSTER SEGMENT 

.INDEX SEGMENT 
.INDEX-ORGANIZED TABLE SEGMENT 
. INDEX PARTITION SEGMENT 
.TEMPORARY SEGMENT 

. UNDO SEGMENT 

.LOB SEGMENT 

.NESTED TABLE SEGMENT 


سوف يأتي ذكر کل نوع لاحقا. 
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DATA BLOCKS 


هي أصغر وحدة تخزين في الأوراكل ويتم تحديد حجمها بواسطة العامل "إم)م 4٣و۲"‏ 
(B_ BLOCK _SIZE‏ عند تکوین ال 46طوtھD‏ ولا یمکن تغییر الحجم فیما بعد. یتکون ال وخ5( 
Block‏ من: 


:B LOC HEADER °‏ يحتوي علی معلومات حول ال gi Data 810k‏ ع4 ) Data, Index,‏ 
10ا ۲ه). يحتوي أيضاً على ال راها٤ءء1۲‏ ء1[ط11 الذي يوفر معلومات حول ال و6اطه٣‏ التي 
لھا بيانات (sس R0‏ )ھ0 ) في ال ء810 044 . ومن أجزاء ال Header‏ )oeاB‏ ایضاً ما 
يعرف باسم راه)ءء01۲ س٠8‏ الذي يوفر معلومات حول البيانات (sس٥8)‏ المخزنة في ال )810 
مٹل Block Header Û ja ريخÎلا ءjجلا .R 0w Address ÛÙ|‏ هي Transaction Slots Û‏ 
التي تستخدم عندما تحدث تغيرات في البيانات "وس80" نتيجة للمهمات "ود 44۾" 
المختلفة. 


."R0س؟" هي المساحة التي يتم تخزين البيانات بها‎ : ۲۸ SPACE 
Data Space Jly Block Header J| ja J هي مIwحã خıة تساعد‎ :FREE SPACE 


على التوسع في الحجم اذا لزم الأمر. في حال حدوث عمليات كثيرة تسبب أخذ مساحة منها ثم اعادة 
مساحة لھا بشکل متکرر یحدث_ ٤,٤4٤10‏ ع4٣۴‏ ويقوم الأوراكل بعملية C٠۸١٥‏ لها. 


تذكر: عملية ال ع«ذعsء41٥€‏ من درس .Locally Managed Taۆ1espaeê J|‏ 


Data Files JI gê Checkpoint JI pãرg‎ og Sequence Number J| تذکر2: یتم تخزين رم‎ 


.Header 
, HEADER__ HEADER 


i SPACE | 


ا 


RTA SPACE = 


الرسم 6.1 


ملاحظة: الأسهم في الرسم 6.1 تشير الى الطريقة التي تكبر بها مساحة كل من ال #ءوم؟ و٤04‏ وال 
B10ck Heder‏ وهي طريقة عكسية » من أسفل الى أعلى ومن أعلى الى أسفل على التوالي. 
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:BLOCK STORAGE PARAMETERS 


يتم تكوين ٥[ط‏ 11 أو عنصر أخر "زا0" یمکن تحدید عوامل تتحکم في ال ء810 ۾ التي 
تنتمى لهذا العنصر. تحديد هذه العوامل مهم جداً > لأنها تعمل على توفير مساحة كبيرة وتحسين الاداراة 
والعمل. 


:P)۴REE ٠‏ عند تحديدها › يتم حجز مساحة من حجم ال ء810 تخصص للزيادة المتوقعة في 
البيانات "وس80 و4(" النانتجة من تغيير "ءلمل" البيانات R0 ws"‏ و4(" في ال 
Bloc)‏ الحجم ال {)اںوDef‏ لھا ھو 10%. 


:P CUED ۰‏ تمثل الحجم الأدني للبيانات "Data Rows"‏ في Block Û‏ الذي اذا قل حجم 
البيانات "س R0‏ و4(" المخزنة داخله عن حجم ال S٤6‏ ا۲٥٤۴‏ ۰ یتم تحویل ال 81٥k‏ الى 
قائمۂ ال ٤1ا٥ ›۴٣‏ الحجم ال )ا uوf 0e‏ هو 40%. 


:FREELIST ®‏ یمن لل m۲‏ عءS‏ الواحدة أن یکون لها آکثر من )ا٥۴۲۲‏ واحدة بتحديد العامل 
Default Û|  FREELISTS‏ هو لكل Segment)‏ واحدة › قائمة ام۴6 واحدة. 


Block Û „û "Transaction Slots" Ji عند تحدیدھا يتم حجز مساحة‎ :[N]"]R ANS 
۲ظ لتخزين البيانات حول المهمات التي تجري. فهي تحدد الحد الأدنى من المهمات‎ 
› 3 ا" التي یمکن أن تجری على ال ه81 في نفس الوقت. اذا تم تحديدها ب‎ ransaction" 
بحيث يمكن أجراء ثلاث مهمات على الأقل على‎ 1۲4,2٥ )1٥۸٧810٤ءرثالث فذلك يعني آنه یخصص‎ 
في نفس الوقت » عن الضڑورة يمكن تخصيص مساحة من ال ٥٥ے م؟ ۴۲۲۲ في ال‎ 81٥) ال‎ 
.1 هو‎ Defa u٤ أخرى› ال‎ "rAhl action S10ts إضافة‎ Block 


Block J „û "Transaction Slots" Ji عند تحدیدھا یتم حجز مساجة‎ :MAXTRANS 
لتخزين البيانات حول المهمات التيإتجري. فهي تحدد الحد الأعلى من المهمات‎ H4 
› 200 التي يمكن أن تجرى على آل81061«في نفس الوقت. اذا تم تحديدها ب‎ "آاansactions"‎ 
فذلك يعني أنه يمكن أجراء 200 مهمة على الأكث علىال ء810 في نفس الوقت› ٤اuںه؟ء50 هو‎ 
.255 


ملاحظة: يقصد بال )و٥٥۴۲‏ بأنها قائمة "٤ء"‏ تحدد ال وعم[ التي يوجد بها مساحة خالية قادرة 
علی استیعاب بیانات جدیدة أو ال cksہ[8 .۴٣٤e‏ 


مثال: 
في حال تم تحدید ال S٤5‏ ل P٥1‏ بنسبة 30% والÛ P1 FREE‏ بنسبة 20%: 


1- يتم ادخال بيانات "س٠8"‏ الى ال 810k‏ الى أن تصل نسبة البيانات المدخلة الى 80% أو أقل بحيث 
يجب أن يظل حجم من ال )810 فارغ وهو نسبة ال P٣] ۴R E٤‏ وهي کما ذکرنا 20% وھکذا یظل حجم 
فارغ من ال )ه810 في حال تغير بيانات »سه8 المخزنة في ال ء810 مثل تحويل قيمة أحد ال 

C0 LUMN‏ من حالة N11‏ الى قيمة فعلية. هذه المساحة الفارغة مخصصة لل 8٠s‏ الموجودة في 
حال تغير قيمها ولا يمكن اضافة R٠ ۷s‏ جديدة لتحل في الحجم الخالي الناتج من تحديد .PCTFREE Û‏ 


2- في حال انخفاض بيانات ال سه8 المخزنة في ال عم[ أو تم حذف عدد من ال Rs‏ › لايسمح 
باضافة وس80 جديدة في ال ع 810 اذا لم تنخفض بيانات ال R٠ ۷s‏ في ال ء810 عن الحد المحدد ب 
۴٣D‏ وهو 30%. في حال انخفاض حجم بیانات ال RW‏ عن ۰30% یتم تحدید أن ال 810k‏ 
جاهز لاستقبال R0 ws‏ جدیدة (٤ءiا ee‏ ۴). 
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MANAGING DATA BLOCKS 
يمكن إدارة ال ءء810 هه( بطريقتين احداهما يدوية والأخرى أوتوماتيكية وهما:‎ 


:MANUAL DATA BLOCK MANAGEMENT 


یتم استخدام Bloc) Storage Para nete‏ في تحدید حجم ال 0ks‌1ا8.‏ 


:AUTOMATIC SPACE MANAGEMENT 


یتم استخدام م ھ٤8‏ عوضاً عن ءا٥٥۴‏ لتحدید ال cks‏ ہ81 Used‏ وال .۴٣۵ 81٥k‏ یتم حفظ ال 
Bitmap‏ في ءء810 مختلفة تسمى e4 810 cs )8M8s(‏ مم2« .Bi)‏ عندما یتم ادخال بیانات 
"Rows"‏ جديدة » يتم البحث في ال مه.)81 عن )ء810 يحتوي مساحة خالية مناسبة لحجم البيانات 
الجديدة المدخلة وعند حدوث أي تعدیلات على Blocks Û'‏ (مثل زيادة المساحة الخالية عن المساحة 
المشغولة) يتم تعديل ال مه811 لتوافق التغيرات التي طرأت. 

فوائد استخدام هذه الطريقة عديدة منها سهولة ادارة ال وم81 اذ یتم تحدید ال [٤؟ا P٤٥۲‏ و ال 
۴R EELST‏ بشكل أوتوماتيكي » تخصيصالميساحة للعناصر "ءءء زط0" بشكل أفضل › وأداء أفضل 
خلال عملیات ال 1 ]NSE‏ المتزامنة. 
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نقاط مهمة: 
1- يمكن استخدام هذه الطريقة مع sع4مء‏ 1ا14 Managed‏ yاا0caا‏ فقط 


2- تطبق الطريقة على مستوى ال ٥ءدمء٥1ط ٠۲4‏ أي يجب أن تكون جميع ال ٤ء"‏ عم$ داخل ال 
espa‏ اbه"‏ تعمل بنفس الطريقة. 


3 لا يمكن تغيير الطريقة الى الطريقة اليدوية بعد أن ت تخدم. 


4- يمكن استخدام هذه الطريقة باضافة جأ SEGMENT SPACE MANAGEMENT AUTO‏ 
ا جlۀ .CREATE TABLESPACE‏ 


5- لا يمكن استخدام الطريقة مع ءءدمءء1طه4 تحوي أو قد تحوي على sو08_.‏ 
ملاحظة: يتم تخزين بيانات كبيرة بواسطة 108s‏ مثل الصور والفيديو وغيرها وسوف يتم التطرق لها في 
فصل لاحق. 
مثال تطبيقي 6.1: 
CREATE TABLESPACE APP DATA‏ 
DATAFILE '...l\loradata\db05\appdata04.dbf"‏ 


EXTENT MANAGEMENT LOCAL UNIFORM SIZE 512K 
SEGMENT SPACE MANAGEMENT AUTO; 
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STORAGE INFORMATION 


للحصول على معلومات حول ال s)رمء"_‏ عم يمكن استخدام: 
:DBA_ SEGMENTS °‏ يمکن الحصول علی معلومات حول اسم ال Seg ٤‏ › ال 
espaceاab r‏ التي تحوي Segment J|‏ <« عد Extents J|‏ في Data JI ıدعg Segment ÛJI‏ 
ء0اB ٠‏ وغيرها من المعلومات. 
للحصول على معلومات حول ال ئ۸4 رع] d ٤×‏ عو یمکن استخدام: 
:D(BA_ EXTENTS‏ یوفر معلومات مثل رقم ال ۸۲ع)×E‏ ورقم ال kعم[8‏ التي ینتمي لھا وعدد 
ال »810 ضمن ال E>)‏ وغيرها من المعلومات. 


للحصول علی معلومات حول ال ئ٤ہرع]×‏ £ ٥ع‏ یمکن استخدام: 


:DBA_FREE_SPACE °‏ یوفر معلومات مثل اسم ال عه مءم1ط ه۲ التي تحوي ال Ex)e٤‏ 
وال وم81 التابعة لها وغيرها. 
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UNDO SEGMENT 


تستخدم ال ۲٠٥رعءS‏ 100ا في حفظ نسخة عن البيانات قبل تعديلها بواسطة المهمات 
"nsactionsها"آ"‏ التي أجريت عليهاء مثلاً لكي يتمكن الأوراكل من استعادة البيانات قبل التعديل في حال 
طلب المستخدم )4 ط11هR‏ عوضاً عن ٤ن‏ ص٥٥‏ . یتم استخدام ال Un d0 Segment Header‏ لتخزین 
بيانات حول المهمات "ناوور وآ" الحالية التي تستخدم .Undo Segment JÛ‏ 


:Undo Segment J| من فوائد استخدام‎ 


ه لكي يتمكن الأوراكل من استعادة البيانات قبل التعديل في حال طلب المستخدم kءوط1[هR‏ عوضاً عن 
.Commit‏ 


ه لكي يتمكن الأوراكل من استعادة البيانات الأصلية في حال تعطل المهمة أو حدوث خلل طارئ لل 
stance‏ يتطلب عملیة ال .Rec0 very‏ 


للقيام بما يعرف ڊlصp .Read Consistency‏ 


ملاحظة: تستخدم المهمات المرتبطة ببعضها Undo Segment « "Serial Tra ږs2 ci0"‏ واحدة فقط 
ويمكن للمهمات المتزامنة استخدام ذاتال .Undo Segê ٤‏ 


تذکر: یتم تخزین معلومات حول ال m٤‏ ع٥8‏ 40ا في: 
.Initialization Parameter File e‏ 
«Alert Log File‏ 
.Control File e‏ 


تذکر2: جاء ذکر ال 1۲ عمS‏ ٥ل‏ ما في درس: 
.Undo Tablespace‏ 
.Offline or Online °‏ 


:System Change Number (SCN) 
Read طہں. ueں ٩1ہ ا" يتم تكوينه عند حوث أمر انسصصه)» ويساعد في عملية ال‎ e۲ ھو رقم ممیز‎ 


Redo Log «< Control Files JI في‎ SCN J| يتم تخزين‎ .Recovery Û| Azle s Consistency 
.Block Headers ۾‎ «< Files 


تذکر: یقوم ال )ذه م )عمط بعمل تجدید لرقم ال ©9 في ال .C٥۸ ٤01 ۴1e‏ 


:Read Consistency 


هي إمكانية رؤية أحد المستخدميين البيانات الأصلية قبل التعديل بالرغم من قيام مستخدم أخر بتعديل البيانات 
في نفس الوقت. لحدوث ال رءمءاءزوره٤‏ 44ء8 يجب أن يكون المستخدم الأول قد طلب البيانات قبل أن 
يقوم المستخدم الثاني بتأكيد التعديلات على التغيرات بواسطة ٤نصصه)‏ » عندئذ يحضر الأوراكل البيانات 
المطلوبة للمستخدم الأول من ال Sg.)‏ 0لم لا. 
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مثال: 


1- يقوم المستخدم الأول بعمل مهمات على بيانات ال 6s[طه٣‏ ءعءعرهام .ع تؤدي الى تغير البيانات مثل 
.UPDATE ule‏ 

2- يقوم الأوراكل بتخزين نسخة لبیانات ال ٣41٥‏ ع رامع قبل التعديل في ال d0 Seg”‏ €ا. 
3 يقوم المستخدم الثاني بطلب استخراج البیانات عبر استخدام Select * From Jû Query‏ 
oyesاEmp»‏ وعندها يتم تحديد رقم ال ©5 الذي يستخدم لضمان عدم عرض البيانات التي يحدث لها 
تغییر ولم یحدث لھا )زر mص٥٤.‏ 

4- البيانات المعروضة على المستخدم الثاني هي البيانات قبل التعديلات التي أجراها ويجريها المستخدم الأول 
و هي البيانات المخزنة في ال Seg"‏ 0لم ا. 

5- يقوم المستخدم الأول بانهاء و تأكيد المهمات التي أجراها باستخدام ازصدصه) » فيتم تجديد ال .S€©١‏ 
6- يقوم المستخدم الثاني بعد قليل بطلب استخراج البيانات مرة خرJ .Select * From Employees‏ 
7- البيانات المعروضة هذه المرة هي البيانات بعد التعديلات التي أجراها المستخدم الأول . 


:Snapshot Too Old Error 


عندما لا يستطيع الأوراكل توفير خدمة ال رءدءاءاوره٤ 8٠44‏ يظهر هذا الخطأ للمستخدم. يمكن أن يظهر 
الخطا عندما يطلب المستخدم الثاني رمں يكون البيانات المستخرجة طويلة جداًء بحيث قبل أن ينتهي ال 
رامQu‏ من العمل يحدث أمران» الأمك الأول هو أن المستخدم الأول طلب ٤ن‏ ص C٠‏ على البيانات › والأمر 
الثاني أنه تم استخدام ذات ال ٥۸۲٤‏ ع٥5‏ ولا من قبل مھمة آخری بحیث تم تغيير البيانات 
.Ûndo Segment JI aê "Overwritten"‏ 

باستخدام العامل U NDO_REFEN TION "Para eter"‏ یمکن تحدید کم من الوقت یسمح للبیانات 
بالبقاء في ال eءaم 141e‏ 10ا وبذلك توفیر خدمةپال رء”ء)ءiو«ه٣ ٥44‏ 8. اذا تم تحديد قيمة العامل 
ب 900 » فهذا يعني أنه يسمح للبيانات البقاء لمدة 15 دقيقة. يمكن تحديد العامل في ال «0نخوz¡اهi)iم1‏ 
Parameter File‏ › ويمکن تعدیلھ دايناميكياً ڊو اسطة .ALTER,Š¥S 1EM‏ 


ملاحظة: اذا كان حجم ال مءومءء[اطهآ ٥لا‏ صغير» يمكن أن تظل البيانات للوقت المحدد بالعامل 
UNDO_RETENTION‏ › حيث يتم استخدام عمليات حسابياةلتبيل البيانات المخزنة. 


:UNDO SEGMENT TYPES 


:SYSEM UNDO SEGMENT *‏ تتکون ضمن ال c٥‏ 4م٥۲۵1‏ ٥۳ءtءرS‏ عند تکوین ال 
bse‏ taهط‏ لتوفر خدماتها للعناصر "ء)ءءزط0" الموجودة ضمن ال .System 1 4b[esم ace‏ 


:NON-SYSTEM UNDO SEGMENTS °‏ عندما يوجد Tab1 espace‏ ي Database JI‏ 
غیر ال esp 2 ce‏ 1ا14 System‏ › يجب توفر على الأقل واحدة Non-System Undo ja‏ 
Segment‏ في ال seھط Data‏ لتخدم باقي ال ھم1 14. 


:DEFERRED UNDO SEGMENTS °‏ یمکن تکوینها عند وضع ال 6ےم٥1ط‏ ۲۵ في حالة 


fine‏ › اذ یمکن أن تستخدم في عمل ا 4ط[1ه8R‏ للمهمات "۹٥1٤ء‏ ھی ,ه۲۲" التي قد تحدث 
عند تحویل ال ce‏ ےمء1ط ھ۲ الى حالة اÛ .Online‏ 
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MANAGING UNDO DATA 


يوجد نوعان لإدارة ال و٤0‏ ململ في الأوراكل هما: 


.AUTOMATIC UNDO MANAGEMENT ° 
.MANUAL UNDO MANAGEMENT ° 


سوف يتم التطرق فقط الى النوع الأول في الكتاب. 


:AUTOMATIC UNDO MANAGEMENT 


يتم تخصيص ء٥4‏ مءء1طا14 140ا واحدة ذات مساحة كبيرة لكل مء« و٤وه[.‏ يتم التحكم في البيانات 
الموجودة في ال مءدمءء1ط 14 0لا بشكل أوتوماتيكي من قبل ال S٥۷۲‏ ء1ء0۲4. يتم تسمية أسماء 
Undo Segment‏ طبقاً للطريقة التالية 1Ş‏ ا _S¥SSM‏ مئل ١1$‏ SM؟S؟¥S_.‏ 

لكي تعمل طريقة ال Automatic Undo Management‏ يجب توفر e‏ p2ءع1‏ اھ1 0لا واحدة في 
حالة ٠۷ذاء۸.‏ بالرغم أنه يمكن أن تتواجد أكثر من ءءومءء1اطه1 0لا في ال مء ط٤(‏ ولکن لا یمکن 
أن يكون أكثر من واحدة في حالة م۷إ)۸. 

لاستخدام هذه الطريقة يجب تحديد العامل_""eteص U ND0O_MANAGEMENT "Para‏ بالقیمة 
U0‏ ۸ في اÛ Parameter File‏ iatiohاهtiا].‏ لا يمكن تغيير قيمة العامل بطريقة دايناميكية بعد 
تشغيل ال ء4 ط D44‏ /القيمة .MANUALQa4MD¢efault Û‏ 

لتحدید ال ce‏ 2م٥۲۵1‏ 0لا التي سوفا یتم التحكم ب بوlسصطة Automatic Undo‏ 
Management‏ يجب UNDO_TABLESPACE '"P4frameter'""لمlعl| ıı‏ في ال 

Data طھse 0لا واحدة في ال‎ 12 ا1esم2‎ ce !ل أن يكون ھتالڭ‎ › [nitialiation Parameter File 
عندئذ لا يشترط تحديد هذا العامل "١ء٤٥ 4١إه۶". يمك,تغيير قيمة هذا العامل بطريقة دايناميكية بواسطة‎ 
.ALTER SYSTEM 


مثال تطبيقي 6.2: 


لتغيير قيمة العامJ U[ND0O_" A BLESPA CE‏ بشکل داینامیکي (للتحدید ٥‏ 2مم1ط۲4 أخرى في حالة 
:(Active‏ 


ALTER SYSTEM SET UNDO_TABLESPACE = UNDOTBSPACE; 


أو عبر ال م1موه٥‏ باتباع الخطوات التالية: 


ادخل الى ال Conso1¢‏ عڊر .Standalone‏ 

م اضغط عڵٿ اسم Database Û|‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

٠‏ أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 S۷85‏ عوضاً عن إوصإه.. 
اضغط على .Instance Manager Û‏ 

.Configuration Jڦزأغ‎ biض)‎ 

٠‏ اضغط على قائمة 0ل لا. 

.Undo Tablespace Û pl Current Undo Tabl1espace ةمnئl أختر من‎ 
.۸م‌ماy اضغط على‎ 
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:Snapshot Too Old Error 


يمكن أن يحدث هذا الخطأ ايضا اذا ما تم تغيير ال #ءءaمء1eط d0 ۲a‏ ا( بواسطة ALTER JI‏ 
SYSTEM‏ أو عبر ال 1eمsر٥€‏ ) وکان ما یزال ر Que‏ یستخرج البیانات من ال 1espaceۆTab Undo‏ 
التي تم تغييرها. 


ملاحظات: 


1- في حال لم يتم کتابة جل CREATE DAT ABASEةlج „ê UNDO TABLESPACE JI‏ « 
وكانت قيمة العامل UND0_MANAGEMENT‏ تساوي ۸0۲0 » فإن الأوراكل سيرفر يقوم بتكوين 
espaceاab €n do r‏ بشكل أوتوماتیكي بىسمى 858 7N(01ا_$؟¥S؟.‏ 

2- يمکن حذف ع٥2‏ م٥1ط‏ ھ۲ 0ل € باستخدام جملة PROP "A BLESPACE‏ التي جاءِ شرحھا 
سابقاً» ولکن لا یمکن حذف ال ےم ء٥1‏ ط٣‏ ٥ل‏ ہا اذا كانت تستخدم بواسطة .(Active)Insta nce J|‏ 


تذکر: 


gİ CREATE DATABASE ÛJI ةlaج مء 1ط ھ٣ 40ہ[ بطريقتيين <« إما عبر‎ 2 ce يمکن تکوين ال‎ -1 
.CREATE) UNDO TABLESPACE ژأaڄ عبر‎ 
.Undo Tablespace Û ي درس‎ Automatic Undo Management J| رÛذ‎ slج‎ -2 


مثال تطبيقي 6.3: 


يمکن حذف ال 4-٤‏ صء1ط ۲4 €0 بواسطة ROP "A BLESPACE‏ ولکن یجب علی کل المھمات 
التي تجري في ال ln d0 "abl esp 2e‏ ان تنهي عملھا قبل اتمام٠غملية‏ الحذف» يمكن معرفة اذا ما کان 
هنالك أي عمليات تجري على ال مء ومءء1طه٣‏ 0لا أو أي“خءةمءء1ط 14 من خلال كتابة التالي: 


SELECT Z.NAME, X.STATUS 

FROM V$ROLLNAME Z, VŞ$ROLLSTAT X 

WHERE Z.NAME IN 

(SELECT SEGMENT_NAME FROM DBA_SEGMENTS 
WHERE TABLESPACE_NAME = 'UNDOTBS') 

AND Z.USN = X.USN ; 


اذا كانت قيمة ال $1۸18 هي PENDING ONL|1NE‏ فهذا يعني أن ال 4۲ ص٥1ط‏ ۲۹ لا یمکن 
حذفهاء أما اذا كانت القيمة هي PENDING OFFLINE‏ فهذا يعني أنه یمکن حذف ال ٥م۶٥1‏ ط۲4. 


:Resource Manager 


يمكن استخدام ال ام وور هة[ ١ء۲ u‏ 0ء8 للتحكم بالنظام بحيث يتم منع المستخدميين أو مجموعة من 
المستخدميين من استهلاك مساحة كبيرة لل وا0 ملا بحيث يتم تخصيص مساحة قصوى "عzزءx۾۷1"‏ 
لكل مجموعة لاستخدامها في تخزين ال و٤٥‏ 0ل ,. يتم تخصيص مساحة قصوى بتحديد ال 

.UNL1M17٤( والذي هو في الحالة الإفتراضية ")[ںوfء 5" محدد بالقيمة‎ UN D0_ P001 
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QUERYING UNDO INFORMATION 


يمكن استخدام ال ۷1٥s‏ التالية للحصول على معلومات حول ال d0 Seg”‏ ا: 


:۷ŞUNDOSTAT °‏ يساعد في تحدید حجم ال ce‏ م٥‏ 1ا٣‏ ٥ا‏ »اذ یوفر معلومات حول 
عمل ال ce‏ ےم ٥1ا۸٦ d٥‏ ہا وضغط البیانات علیها خلال 10 دقائق. 


SELECT BEGIN_TIME, END_TIME, UNDOBLKS 
FROM VŞUNDOSTAT; 


:D(BA_ N ROLLBACK_SEGS °‏ للحصول علی معلومات حول جمیع ال .٤۲‏ عع 014٥‏ فقي 
ال base‏ هغه .D‏ وحدها فقط توفر بیانات حول .Offline Segment J|‏ 


SELECT SEGMENT_NAME, TABLESPACE_NAME, OWNER, STATUS 
FROM DBA_ROLLBACK _SEGS; 


.Online Segments JI gaج توفر اسماء‎ :YŞROLLNAME ° 
SELECT USN, NAME FROM VŞROLLNAME; 


:YŞROLLSTAT °‏ توفر بیانات.خول ال 01ine Seg mes‏ مثل حجم ال "٤٤s‏ عمS‏ وعدد 
ال Ex) )s‏ وغيرها. يمکن عمل Join‏ مع  ŞROLLNAME Û!‏ بواسطة اÛ .USN‏ 


SELECT A.NAME , B.EXTENTS 


FROM V$ROLLNAME A , VŞROLLSTAT B 
WHERE A.USN = B.USN; 
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اذمل اساج 


أدار التايل و الاندكسصس 
والكونبسنرانيت 


Managingtables & indexes & 
constraints 
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STORING DATA 


یتم تخزین ال 0۸۲۸ في أوراکل علی شکل وس80 و ک«صں‌اه٥‏ في ال 16ط ۲۵. يوجد عدة آنواع من ال 
"abe‏ مثل: 


"ABLES‏ )أو Tables‏ arاRegu):‏ هي ال ما4٣‏ التي يتم معظم العمل عليها والتي يكون 
التحکم بتوزیع بال 8٥W‏ فیھا من وظائف ال .O r21e Sever‏ 


:PARTITIONED TABLES °‏ يکكون Table JÛ‏ أکثر من جزء "٤٤و٣"‏ كل جزء 
عبارة عن ٥٣۲‏ عع S؛‏ کل "عص عع$ یمکن ان تتواجد في ٥٥‏ 2مءء1ط ۲1 مختلفه. 


:][NDEX-ORGANIZED TABLE °‏ یجب تخصیص ال ۴Primary Key‏ لل b1e‏ ھ٣‏ ویتم 
تخزين ال ۴ وال م[اط ه٣‏ في ذات المساحة › وذلك عکس ال ٥1ا۸٣‏ إواںعمR‏ التي اذا تم تكوين 
×۴ لها (الإثنان في مساحة مختلفة .("Separate Storage"‏ 


:)LUS1 ERED "ABLE‏ يمكن أن تتكون من ء[ط 11 واحدة أو مجموعة من ال وم[إطه1 
التي تستخدم مع بعضها بحيث تتشارك نفس ال وkءم[8‏ ۾4(. یوجد ما یعرف باسم r‏ مtیں[C‏ 
ره الذي يحدد ال سه8 التي يجب أن تخزن مع بعضها البعض. 


:DATA TYPES 


يوفر الأوراكل مجموعة من يمم رآ هه( لتخزين البيآثات › تتبع ثلاثة أنواع هم Scalar, Collection,‏ 
.Relationship‏ 


:Scalar Data Types 
:Scalar Data Types بعض أنواع ال‎ 


:CHAR, N CHAR‏ توفر مساحة ثابتة" ٤ع«‏ ع8-1ء×۴1" لتخزين الأحرف 
."Characters"‏ المقصود بالمساحة الثابتة أنه عند تخصيص مثلاً و»)رB‏ 10 وتم شغل 7 
8 لتخزين البيانات» لا تعتبر ال وم)رط3 المتبقية مساحة خالية بل مساحة مشغولة. أقصى قيمة 
(مساحة) يمكن اختيارها هي 2000 بايت لكل س80 مع العلم أن القيمة ال )إاuںوfءD‏ هي 1. تختلف 
NCHAR‏ عن CHAR‏ أن الأولى يمكن أن تخزن إء)ء4إ2ط٤‏ م هء1 ما التي توفر خدمة تعدد 
اللغات. 

:YARCHAR2, NVARCHAR2‏ توفر مساحة متغیرة "1ع" 1e-1eطھriھ‏ ۷" لتخزین ال 
امهم“ ×. المقصود بالمساحة المتغيرة أنه عند تخصيص مثلاً وم) ر8 20 › واحتاجت البيانات 
المخزنة في ال صصںاهC‏ الى وم٤رط‏ 15 فإنه يتم استخدام وم ر8 15 فقط من المساحة الخالية 
لتخزين البيانات › ولا يتم حجز المساحة الكلية المحددة. أقصى مساحة يمكن اختيارها هي 4000 
بايت لكل سه8 مع العلم أنه لا يوجد قيمة )اده( ( يجب تحديد القيمة). تختلف 
ARCHAR2 ùe NVARCHAR2‏ ۷ أن الأولی یمکن أن تخزن c٥ de C124)‏ 1ہ ا التي 
توفر خدمة تعدد اللغات. 

38 ل: توفر مساحة متغيرة لتخزين الأرقام. يمكن أن تستوعب المساحة أرقام تتكون من‎ UM BER 
خانة.‎ 
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۵ ۲۳ : توفر مساحة ثابتة لتخزين التاريخ والوقت. توفر سبع خانات للقرن والسنة واليوم 
والساعة والدقيقة و الثانية وأقصى تاريخ يمكن أن يخزن هو ال31 من ديسمبر لعام 9999 › أما أقدم 
تاريخ يمكن أن يخزن هو يناير من عام 1.4712 قبل الميلاد. 

:"]MESTAMP‏ توفر خدمة مماثلة لل ۸1۳۴ عدا أنها توفر مساحة إضافية لتخزين أجزاء 
الثانية. توفر 9 خانات لتسجيل أجزاء الثانية (0.987654321 ) والعدد ال ٤اuںوfهD‏ هو 6 خانات. 

:r"1]MESTAMP WITH TIME ZONE‏ توفر خدمة ممlأlة TIMESTAMP Ji‏ › !ل 
انها توفر مساحة إضافية لعرض الفارق الزمني بين المستخدم والتوقيت العالمي (توقيت جرينتش). 
يظهر الفارق على شكل عدد من الساعات والدقائق فقط. 

:"]|MEST AMP WITH LOCAL TIME ZONE °‏ توفر خدمة مماثلة لل 
"]MESTAMP‏ » إل انها توفر مساحة إضافية لعرض ال 70e‏ مه1 «10وومS؛‏ الذي 
يستخدم في إدخال البيانات بين فروع الشركات البعيدة عن بعضهاء أي في حال ادخال البيانات من قبل 
المستخدم الأول الذي بينه وبين المستخدم الثاني زائد 3 ساعات زمنية › فإن المستخدم الثاني يرى 
توقيت إدخال البيانات بتوقيته هو ( زائد 3 ساعات زمنية) و ليس بتوقيت المستخدم الأول الذي أدخل 
البيانات. يظهر الفارق على شكل عدد من الساعات والدقائق فقط. 

2000 توفر مساحة متغيرة لتخزين ال واد رإه81. أقصى مساحة يمكن اختيارها هي‎ :۸R0W۷ ٠ 
بایت.‎ 

:10NG RAW‏ توفر خدمة مماثلة لل سه8 ولكن مساحة كبر 268 (لا ينصح باستخدامها) 

ه :10N6G‏ توفر مساحة كبيرة لتخزين البيانات › يمكن أن تصل المساحة الى 268 (لا ينصح 
باستخدامهاء ویفضل استخدام ٥1.08‏ أو .))N٤108‏ لا یمکن لل ٥1ط‏ 14 أن تحوي أكثر من 
l108‏ واحدة. 

.Character Data Û| ùڍjختل‎ 4G BAW رiوت‎ :CLOB, NCLOB ° 

gy Binary Images Jia Unstructured Data ڻيزiil‎ 46B توفر مساحة‎ :BLOB 
.Documents 

:B۴] LE ۰‏ باستخدامهاء تستطيع تخزينبيانات خارج ال مووطه)دD‏ في ملفات خارجيةء يمكن أن 
يصل حجم الملف الخارجي الى 468. 

:ROWID, UXROWID °‏ توفر مساحة k٥‏ رط 10 لتخزین رقم ممیز لکل سه8 في ال 
6ط )هط ليستطيع الأوراكل تحديد ال 8٠W‏ بسلرعة أكثر عند البحث على البيانات. الفرق بين 
UX ROWIDs ROWID‏ أن الأخیرۃ توفر میزۃة تسجیل رقم ممیز ل 8W‏ تتبع ]ء014-٥۸‏ 
ئه م( أي من نوع مءaطه٤هD‏ اخر غير الأوراكل), 


:Collections Data Types 
يوجد نوعان فقط هما:‎ 
عبارة عن مجموعة مرتبة من البيانات التي تتكون‎ :YAR YING ARRAYS (VARRAY) 
من نفس ال ٠م رآ و٤4( (مثلاً جميع البيانات أرقام).‎ 


:NESTED "ABLES ®‏ عبار ة عن مجموعة غير مرتبة من ال Rs‏ › تخزن ال 80۷s‏ بشكل 
منفصل عن ال ٥1ا۲۸‏ بحیث یوجد وصلۂ ۲ع ہ1٥۴"‏ من کل 8٥W‏ الی ال eاطھ٣.‏ 


:Relationship Data Types (REFS 


يتم استخدام ءم)م ذه۴ لتدل على بيانات مخزنة في وم1اط ه1 مختلفة. 
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MANAGING TABLES 


:CREATE TABLES 


لتکوین 1۲ا1 ۰ یتم استخدام جملة (PRA E٤ "۳A B٤‏ التي من المفروض قد تعرفت عليها بالتفصيل 
خلال دراستك للامتحان الأول t٥ 3Q"‏ «0Èuc)i0إاما".‏ لكي يستطيع المستخدم تكوين ٠1ا1‏ في ال 
Schema‏ الخاص به › يجب أن يکون لدی geٍvi[eڼ CREATE TABLE pr‏ › أما لتکكوين 141e‏ في 
Seh 85‏ لمستخدمين أخرينء يجب أن يكو دي4 .CREATE ANY TABLE privilege‏ 


عند تکوین ال ۶٥1ھ :٣‏ 
توزيع كل ٥1ط ١۸‏ على ءءومءء1ط۲4 مختلفة عن ال ومع وموم [ط ه٣‏ التي تحوي ملم ا 
.Indexes gyÎ Temporary Segments yi Segments‏ 
٠‏ استخدام نظام ل Ma" age‏ رااهء0[ (أي بدون استخدام جملة ال معوإم)S)‏ لتجنب ال 
.Fragmentation‏ 


مثال تطبيقي 7.1: 
لتكوين Ma24 141٥‏ yاادء‏ 0[ يمكن كتابة: 


CREATE TABLE'HR DEST 
(FIRST VARCHAR2 (10), DAST NUMBER); 


أو يمكن اضافة التالي: 


CREATETAÃBLE HR.TEST 
(FIRST VAREHAR2 (10), LAST NUMBER) 
TABMJÊSPACE EXAMPLE 
PÇTFREE 10 PCTUSED 20 
MAXTÊANS 200 MINTRANS 1; 


على اعتبار أن ذکر »۲ABLESP ACE EXAMPLE‏ یدل على اسم ال ٥٥و‏ میم1ط ه۲ التي تحوي ال 
ما وهي في هذه الحالة ء»دمءء1طه٣‏ مامص ه×5٤.‏ وفي حال عدم ذكر هذه الجملة يتم اختيار ال 
Default‏ وهي عادة ما تکون ال 1esp ace‏ اھ1 .System‏ مع العلم آنه تم تكوين ال 1۲ا۲ في ال 
Schema‏ الخاصة بالمستخدم HR‏ . 


أو عبر ال #اموهC‏ باتباع الخطوات التالية: 


ادخل الى ال .Standalone رڊۈعe Console‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 $۷90 عوضاً عن إومإه.. 
اضغط على + بجانب .Schema Manager J|‏ 

اضغط بواسطة الزر اليمين على م[ط ه٣‏ ثم اختر ٥۲٠١4٤٠‏ من القائمة. 

ادخل المعلومات المطلوبة (مثل اسم ال 1۲ط )٣۵‏ ثم اضغط على رامم۸ 

یمکن اختیار Create لsiہع ¡za‏ عوضاً عن C۲٥)‏ لتسهیل تکوین ال ۲[ط۲۵. 


109 


مثال تطبيقي 72 
لتكوين Dictionary Ma12 ged 141e‏ يمكن كتابة: 


CREATE TABLE HR.TEST2 
(FIRST VARCHARS2 (10), LAST NUMBER) 
TABLESPACE EXAMPLE 
PCTFREE 10 PCTUSED 20 
MAXTRANS 200 INITRANS 1 
STORAGE (INITIAL 200K NEXT 200K 
PCTINCREASE 50 
MINEXTENTS 1 MAXEXTENTS 5 
FREELISTS 1 FREELIST GROUPS 1 
BUFFER_POOL DEFAULT) ; 


في جملة ال eچ04غS‏ : 


. Extent Jgأ تحدد جم‎ :INITIAL 

:NE×X1‏ عند زيادة حجم البيانات يتطلب ذلك اضافة ٤٠ع)×>۴E›‏ حيث تحدد جحم ال "٤‏ )×5 الثانية. 
:P)1NCREASE‏ تحدد حجم ال ×6٤‏ التالية (ليست الثالثة فقط › إنما كل ما يأتي بعد الثانية) 
باضافة نسبة منوية. مثلاً في هذه الحالة”يصبح حجم ال وہ )× التالية 300K)‏ (2006+ نصف حجم 
.(Extent Û (%50)‏ 

.۲۵ التي یمکن أن تخصص لل 1۲ط‎ E81٤ الحد الأدنی من ال‎ :MINEXTENT 
.٣ه‎ (1٥ الحد الأقصی من ال یآگم)×E التي یمکن أن تخصص لل‎ :MAXEXTENTS 

.۲۸ عدد مجموعات ال tءiامعع۴ التي یمکن أن تخصص لل 1۲ا‎ :FREELIST GROUP 
عدد ال istاeء۴ ضمن المجموعة؛‎ :FREELISTS 

(Default Keep, Recycle) lw 4l Iiãرط¦î‎ :BUFFER_POOL 


ملاحظة: لا يشترط كتابة كل عوامل ال م#عهإه)$ » اذ يمكن أخد القيمة ال ٤ا‏ وء( لكل عامل. 


.Locally Managed Taؤۆl1e‎ J| تذکر: ينصح باستخدام‎ 


أو عبر ال ٠01ء٠٥‏ باتباع الخطوات التالية: 


ادخل الى ال s01¢ئCon‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S584؟S۷‏ عوضاً عن إوصإه.. 

„Schema Manager Û + اضغط عٺى‎ 

اضغط بواسطة الزر اليمين على م1ط ه1 ثم اختر ه٤ج٠إC‏ من القائمة. ثم ادخل المعلومات المطلوبة 
مث بيlنات Initial Size, Next Size, Increase Size by, Freelists, Groups, J|‏ 
.Buffer pool‏ 


.۸ اضغط على راصم‎ ٠ 
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:CREATING TEMPORARY TABLES 
لتخزین بیانات مؤقته تلزم فقط خلال القيام بأحد المهمات‎ ۲٥" م٥٣۹۲ یمکن تکوین 1۲ا۲۵‎ 
أو طوال فترة عمل ال «هذوومS» أي في الحالة الأولى يتم حذف البيانات بعد الإنتهاء من‎ "آاansaction"‎ 
المهمة (مثلاً كتابة انصم_ه٤)» أما في الحالة الثانية يتم حذف البيانات بعد خروج المستخدم من ال‎ 
.Database 
«CREATE GLOBAL TEMPORARY TABLE pIدڏختwا‎ pî Temporary Table ùيyكت‎ 
ولتحديد اذا ما كانت البيانات سوف تحذف بعد المهمة أو بعد انتهاء ال رهذووم؟ يتم إضافة الجمل التالية:‎ 

:0N COMMIT DELETE ROWS °‏ تحذف البيانات بعد انتهاء المهمة. 

٥N COMMIT PRESERVE ROWS °‏ : تحذف البیانات بعد انتهاء ال «ه‌ذووم؟. 
تذكر: ال «10وومS‏ من الفصل الأول. 
ملاحظة: یمکن تکوین ۷1ew s, 1], e× es‏ على ال 141e‏ راهم em‏ كأي 16ا۲4 أخرى. 
ملاحظة2: مھمات (INSERT, DELETE Jû) DML J|‏ التي تنفذ عڵذ Y Temporary Taۆle ÛJI‏ 
تؤدي الى تکوین بیانات في .Redo Log Files‏ 
مثال تطبيقي 7.3: 
لتکوین ۲41٥‏ ۲4۲ه م٥۲‏ یتم حذف بیاناتهایبعد انتهاء ال "ه‌زووم؟: 

CREATE GLOBAL TEMPORARY TABLE TEMP _ TABLE 


(TEMP_NAME VARCHARZ2 (25), TEMP_DATE DATE) 
ON COMMIT PRESERVE ROWS; 


:ALTERING TABLES 


يمكن القيام بعدة مهمات باستخدام lئجأة :ALTER TABLE‏ 


:Changing the Block Storage Parameters 


يمکن تغيير قيم PCED, PCTFREE, MAX TRANS,‏ ول یمکن تغییر ال e‏ ھم٥1ط‏ ۲ التي 
تنتمي لھا ا .MINTRANS y Table‏ 


ملاحظة: يمكن تغيير بعض عوامل جملة ال eعھ۲ه)؟‏ مثل ال )ینا ۴۲6. 
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مثال تطبيقي 7.4: 


ALTER TABLE HR.TEST2 
PCTUSED 40 
PCTFREE 20 

MAXTRANS 250; 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


ادخل الى ال .Standalone رڙڊe Console‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 S۷955‏ عوضاً عن إوصإإه.. 

.Schema Manager J| + اضغط على‎ 

اضغط على + ال 1۲ط 1۵. 

اختر اسم المستخدم الذي يملك ال ٥1ط‏ ه٣‏ المراد تغيير خواصها (مثل 4/۸) 

اختر اسم ال م1ط ه٠٠‏ من النافذة اليمنى و اضغط عليها مرتين (أو بواسطة الزر اليمين للفأرة › اختر 
من القائمة ."ViewEdit Details"‏ 

٠‏ ادخل الى قائمة #عدإه)S‏ » وعدل البيانات ثم اختر رامم۸. 


:Manual Allocating Extents 
بشكل يدوي الى ال ٥1ط 11 باستكد(م#القاعدة التالية:‎ E×)٥" ٤و يمكن اضافة‎ 


ALTER TABLE [schema.]table&name 
ALLOCATE EXTENT 


[ 
SIZE number [K|M] 


DATAFILE ‘filename’ 
1 


اذا لم تتم كتابة جملة 1E number ]K|M[‏ › یتم تحدید حجم ال ٤ہ‏ م)٤×E‏ بناءاً على الحجم المحدد ب 
NEXT‏ » أما اذا لم تتم کتابة جملة ال ”¢nص DATA FILE ‘fil ena‏ » فیتم اضافة ٤×)‏ الى أي Data‏ 
۴e‏ ضمن ال e‏ ھمsء1ط‏ ھ۲ التي تحوي ال 1۲ط۲4. 

مثال تطبيقي 79 

لإضافة E×)٥.۲‏ بشكل يدوي يمكن كتابة: 


ALTER TABLE HR.TEST2 
ALLOCATE EXTENT; 
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:Moving Tables 


یمکن نقل 1۲ط ھ۲ (بشرط أن لا تكون 1eط‏ 12 )Partitio 1e4‏ من espaceاrab‏ الى espaceاab r‏ أخرى 
باستخدام جم‘ .ALTER SYSTEM ge MOVE‏ 
عند عملية نقل ال ۲41٥‏ یمکن تغییر ال ءم)e‏ ۴۸۲4 ٥عه۲ه)S‏ كما في المثال 7.6. 


ملاحظة: يمكن تنفيذ العملية لتغییر خواص ال ۴۸۲۸.٤٤٥۶‏ ۵ع۲4٥)‏ دون نقل ال 1۲ ط۲4 الى 
espaceاab"‏ أخری (بنقل ال ۲۵1۲ من "٥۸٤‏ عم؟ الى أخرى) كما في المثال 7.6. 


ملاحظة2: يحب اعادة تعريف ال وم×م ل .]1 الخاصة بال 16ا4٣‏ التي تم نقلها لتجنب الأخطاء. 


مثال تطبيقي 7.6: 


ALTER TABLE HR.TEST2 MOVE 
TABLESPACE APP DATA 
STORAGE (INITIAL 300K) 

PCTUSED 30 
INITRANS 2; 


لتغییر Storage P24٤5‏ دون <نقڭ°ال7 م۲41 الى 4e‏ 1espا‏ ھ۲2 أخرى: 
ALTER TABLE HR.TEST2 MOVE‏ 
TABLESPACE EXAMPLE‏ 
STORAGE (INITIAL 300K)‏ 
PCTUSED 30;‏ 


مع العلم أن موقع ال 712 ]۸.۲٤9‏ هو ال #cومءءاطه٣‏ ءاصة×ع قبل المهمة. 


:DROPPING TABLES AND COLUMNS 


Truncate a Table 

باستخدام أمر "PRU NCATE "ABLE‏ » يتم حذف جميع بيانات ال م1ط 14 واستعادة المساحة المشغولة 
(زيادة المساحة الخالية) التي كانت تشغلها البيانات. تعتبر "PRU NCATE TABLE‏ من أوامر ال 
DAA DEFINITION LANGUAGE (DDL)‏ » وبالتالي فإنھا لا تسبب تکون ٥4٤4‏ لہا علی 
اعتبار أن أوامر ال D1‏ لا يمكن أن يحدث لها kءوط1[1ه8R‏ (أي أنه لا يمكن استعادة البيانات بعد حذفها). 
ملاحظات. 


1- استخدام PR UNCA TE TABLE‏ يودي الى حذف ال 4٥×‏ م!] الخاصة بهذه ال 1۲ا۵٠.‏ 
2۔ لا یمکن استخدامھا علی e[ط‏ ھ٦‏ لھا علاقة ر ع٤٣٥۴‏ مع 16طھ۲ أخری. 
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مثال تطبيقي 7.7: 
يمكن للمستخدم 11۸ كتابة التالي : 
TRUNCATE TABLE TEST2;‏ 
أما ال 084 أو أي مستخدم أخر يملك الصلاحیات "عع ء۴1" اللازمةء فيجب ذكر ال وع طء؟: 


TRUNCATE TABLE HR.TEST?2; 


:Drop a Table 


یمکن حذف م1ط۲۸ بالکامل مع بیاناتھا باستخدام أمر R0۲ AB) E‏ . يجب إضافة جملة ‏ 
CASCADE CONSTRAINTS‏ اذا کان لل b[e‏ ھ٣‏ علاقۂ reign key‏ ۴0 مع 16ا۲4 أخری. 


مثال تطبيقي 7.8: 
لحذف مء1طه٣‏ بالكامل من ال مووطهa٤54?‏ 


DROP TABLE HRATEST?2; 


:Dropping a Column 


یمکن حذف ۸ط ںآه٥‏ والبیانات التي یحویھا من ال 1e‏ ط۲۹ باستخدذام ER۸ ۲۸ BE‏ ۸1۲ . قد تتطلب 
عملية حذف رص_ںآاه٤‏ مدة طولية جداً و معدم؟ ملا كبيرةجكآالل وم1طه٣‏ التي تحوي بيانات ضخمة 
جداً. في هذه الحالةء يفضل وضع ال «n‏ ںاه١٤‏ ضمن قائمة ال S٤5‏ .ال ثم حذفه بعد الأنتهاء من وقت 
الذروة (أي عندما تكون المهمات التي تجري على ال ٥1ا‏ ه٢‏ قليلة). 

وضع ال رص ںاه) في حالة ال [٤SاNا‏ » هو مشابه لعملية حذفه (لكنه في الواقع موجود)» اذ لا يمكن 
استخراج البيانات من أو مشاهدته عند استخدام مر .DESCRIBE‏ 

استخدام أمر ۸L۲ ER TABLE‏ لحذف ہہصuاہC‏ ۰ یسمح فقط بحذف رہصںاہC‏ واحدۃ کل مرةء ولکن 
باستخدام ٠ UN S٤3‏ يمكن وضع أكثر من رص ں اه٥‏ في هذه الحالة ثم حذفها جميعا في نفس الوقت. 
يجب إضافة جل CASCADE CONSTR۸AIN1S‏ اذا کانù Foreign key ةقاle Column Jd‏ مغ 
C1lımn‏ آخر. 


ملاحظة. يحب على الأقل أن یبقی «صںuاه€‏ واحد في ال اه٣‏ بعد الحذف وإلا لن تنجح عملية الحذف › 
ولا يمكن استرجاع ال رصن اه٥‏ المحذوف بعد حذفه. 
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مثال تطبيقي 79 
لحذف ,رہ ںاہC‏ بشکل مباشر: 


ALTER TABLE HR.TEST 
DROP COLUMN LAST CASCADE CONSTRAINTS; 


في حالة ال م ںاه٥‏ الذي يحوي بيانات كبيرة » وتوقفت عملية الحذف قبل حذف ال مص ںاهC‏ يمكن كتابة: 


ALTER TABLE HR.TEST 
DROP COLUMNS CONTINUE; 


:UNUSED ll في‎ Column لوضع ال‎ 


ALTER TABLE HR.EMPLOYEES 
SET UNUSED COLUMN PHONE_NUMBER CASCADE CONSTRAINTS; 


:Unused Columns Û أحذف‎ 


ALTER TABLE HR.EMPLOYEES 
DROP UNUSED COEUOMNS; 


:OUERYING TABLE INFORMATION 


لمعرفة ال وص uاهC used‏ ما في ال 11e‏ یستخدم : 


:DBA_UNUSED_COL_ TABS °‏ يوغر معلومات حول اال و« ں1٥٥‏ الموضوعة في حالة 
UNUSED‏ » و اسم ال م۲41 واسم المستخدم المالك لل ۲[(ه1. 


للحصول على معلومات حول ال ااه يمكن استخدام: 


:D(B A_1 ABLES °‏ یوفر معلومات عدیدة مثل اسم ال 1۲ا۲۹ واسم ال ع٥‏ م٥1ط‏ ه٣‏ التي تنتمي 
لها ال 1ط ه١‏ و اسم المستخدم الذي يملك ال ۲1e‏ وخواص ال S٥۲4٥‏ (مثل DغUSEا )°P٤٥1‏ 
و غیرها. 

.۹[۲ من ضمنھا ال‎ "0طز٥‎ c٤" یوفر معلومات حول جمیع العناصر‎ :D(B۸_OBJE٣CTS 
من المعلومات المتوفرة اسم العنصر و توقيت تكوينه و الحالة التي هو عليها و غيرها من‎ 
المعلومات.‎ 


للحصول على معلومات حول ال sرصں‌اه٤‏ في ال 1۲ ط۲4 یمکن استخدام: 
:DB A_۲ ۸B_ COLUMNS °‏ یوفر معلومات عدیدۃة مثل اسم ال 1eطا‏ ھ٣‏ واسم اÛ Column‏ 


وخواص ال ۲ہ ں‌اه٥‏ وغیرھا. 


ملاحظة: كما يوجد view‏ باسم BLES‏ 8۸_1۸( ıوجد‏ ايض USER_TABLES‏ 
L1 "ABLESg‏ . تذكر اقسام ال وس۷1 راه« )ء1( في الفصل الثالث. 
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MANAGING INDEXES 


یساعد ال ٥×‏ "1 في تسریع استخراج البیانات من ال 6s[ط‏ ھ۲ كما يخفف من ال Input)/O utp ut‏ 
الناتج عن ال وعاإمں (لأنه يمنع حدوث بحث كامل على ال م[ط ه٠‏ للحصول على البيانات). يوجد 
خواص مشترکة بین ال 1۲ا۲۹ و ال چم لہ[ء حیث کما أنه یمکن تکوین ٥1ا۲۹ ۴۹٤٤٥۸4‏ یمکن 
أيضاً تکوين ›Partitioned 1¬ e×‏ ايضاً يوجد Storage Parameters‏ لل dex‏ ہ1 مشابه لل 
.Table Jİ Storage Parameters‏ 

يمکن أن يتم تکوین ال ×م لم[ ل مص ں1٥‏ واحد فقط ويسمى في هذه الحالة >مdم]‏ ماعم¡؟ »› كما 
یمکن تکوین ال ×1۵ لیشمل أکكثر من رص ںاه) (الحد الأقصى ورصں‌اه٤‏ 32 ) ويسمى في هذه 
الحالة e>‏ لم[ مtزوممC0m.‏ لا يوجد حد لعدد ال و»×م .]1 التي يمكن تكوينها على ال ما11 › ويتم 
ادارة ال dex‏ ہ1[ من ãبJ .Oracle Server J|‏ 


من أنواع ال × dم]:‏ 


۸0s یمکن تکوین هذه النوع لضمان عدم وجود بیانات متشابه في ال‎ :UN]QUE INDEX 
علیه.‎ ]! ٥× ضمن ال رہ ں!1ه٤ الذي تم تکوین‎ 

:NON-UN[QUE INDEX‏ یسمح هذه النوع بتشابه بیانات ال 8٥۷s‏ في ال !ه٤‏ الذي 
تم تکوین لم1 علیه. 

:۴UNC]]0N-BASED INDEX °‏ يمكن تكوين هذا النوع لتسريع استخراج البيانات من ال 
85ا التي تحتوي علئرعطلیات مختلفة"وږ من)رں ۴" مثل استخدام ال S18‏ 9708 أو 
NSTR‏ |[ أو "REPLACE‏ أو غیھا في ال .€01u mp‏ 

:PARTITI[ONED INDEX °‏ تم تکوین أكثر من ]N5 ٤×‏ في أکثر من ٥۲‏ "ع8 في 
ءاه" مختلفة. يستخدم لل"وم]136 التي تحوي بيانات كبيرة جداً وغالباً ما يستخدم لل 
.Partitioned Tables‏ 


.Bitmap Index ys B-Tree Jh dex lak اعتماداً على نموذجين‎ [n> يمکن أن يتم تكوين ال‎ 


:B-TREE INDEX 


التكوين الداخلى لل مم1 يكون على شكل شجرة لها أصل وفروع. تتكون الشجرة من ثلاثة أجزاء هي ال 
Rt‏ المتصل بال وط ه8 المتصلة بال fsهم.]‏ التي تحتوي على ال وم٤٤ [4٥×‏ التي تشير أو 
تدل على ال s‏ سه8 في ال ٥1ط‏ ۲۹ باستخدام ال ء٤ءز W15s‏ ۸0 . في الرسم 7.1 يدل الرقم 1 على ال 
Rot‏ » الرقم 2 علی ال ط٤۸‏ ھ8۲ والرقم 3 علی ال fھوع.‏ 


يتکون کل ال ر٤٤‏ ×14 من أربعة أجزاء هي: 


EADERګH:‏ یتم تخزین فیه عدد ال ومصںاه٥‏ التي تعتمد على نوع Single, ) Index Û‏ 
.(Composite‏ 

٤0L0 MN LENGTH °‏ : الذي یحدد حجم ال رص .C٥01u‏ 

.C01u n الذي یحدد قیمة ال‎ : 0L MN VALUE 

. ۲۹1۲ في ال‎ 80s الخاصة بال‎ ۴0W 15s أرقام ال‎ :ROWID 
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TABLE'S ROWS 
7.1 رسم‎ 


ملاحظات: 


1۔ عندما یحدث عملیة 1e7 INSERT‏ ط4 یقوم الأوراکل بإاضافة ر٤٤ ٥×‏ ۵ہ[ جدید لیمثل ال R٥ ۷Ws‏ 
الجديدة المضافة. 

2- لا يمكن الإستفادة من ×٥لږ] 8-1۲٠۲‏ فلي ال sس R٠‏ التي تحوي على ل ". أي عند البحث بواسطة 
جل WHERE‏ عن قيمة )where اast_ namê z null) NULL‏ فإن الأوراکل یقوم باجراء بحث کامل 
على ال 16ا4 ولا يقوم باستخدام ال چهلم1. 

3- يفضل استخدامها على ال رص ں1٥‏ الذي يحوي بيانات مختلفة (مميزة) كبيرة مثل أرقام الهاتف 
وعناوين الموظفين . 

4- لا يفضل استخدامها على ال ور ں 1ه التي تتعرض لجملة ٠ل 0R‏ بشكل مستمر. 


:BITMAP INDEX 


التکوین الداخلی لل مل ,] یشبه تکوین ال 8-1۲۲۲ عدا عن استخدام ۸0W15s‏ يتم استخدام خريطة 
بایتات "81).۸4" لتحدید ال و سه8 في ال ٥1ا۲۵‏ بحیث یمثل کل بایت ۸0W 1D‏ . 


ملاحظات: 


1- یفضل استخدامها على ال «صںآه) الذي لا یحدث لبیاناته تجدید مستمر )٥'"‏ ھلما 0Wا"'.‏ 

2 يفضل استخدامھا عند استخدام WHERE‏ أو 0R‏ بشکل متکرر. 

3- يفضل استخدامها على ال م1ط ه٠‏ التي تحوي بيانات كبيرة جداً ونسبة البيانات المختلفة (المميزة) فليل 
جداً مثل نوع الإنسان (ذكر أو انثى). 

4- عندما یحدث تغییر لبیانات ال رص ں‌اه٤»‏ يتم تجديد ال مه ")8 لتناسب التغيير. 


117 


:CREATING B-TREE INDEXES 
قبل تکوین ال ×ملم] ينصح بالتالي:‎ 


تكوين أقل عدد ممكن من ال و»×٥‏ لم[ على م1طه1 تجري عليها عمليات D11‏ كثيرة» لأن ال 
»ع14 يبطئ هذا النوع من العمليات. 


٠‏ وضع ال 6s×ل‏ م[ في aceمءء1ط14‏ خاصة. 

اختیار 61×6 N٥106‏ لل e×es‏ 4ہ[ الکبیرة. 

ه قيمة العامل ۸۸8 ]N]۲۸‏ يجب أن تكون أكبر من مثيلتها التي حددت على ال 1۲طه٣.‏ 
لتكوين × لہ[ 8-1۲٠۲‏ يجب اتباع القاعدة التالية: 


CREATE [UNIQUE] INDEX index name 

ON [schema.[]TABLE (Column [ASC | DESC] , Column [ASC|DESC] , ...) 
[TABLESPACE tablespace_name] 

[PCTFREE number] 

[IMAXTRANS number] 

[MINTRANS number] 

[LOGGING | NOLOGGING] 

[NOSORT] 

[STORAGE INITIAL number K|M NEXT number K|M .....] 


فی القاعدة: 
:٣۲۴R EE ٠‏ هي المساحة التي تحجز في كل )8106 عند تكوين ال × م[ لكي تستقبل ال 
»م [n4‏ الجديدة. 
:N0S0R‏ تحدد أن ال 8٠۷s‏ مرتبة بالترتيب التصاعدي وبالتالي لا يجب على ال ماع0 
Server‏ ترتیب ال R٥ ۷W‏ عند تکوین ال ×eہ1.‏ 
:ASC|][( E٥ ۰‏ تحدید اذا ما کان علی ال ©۲4٤1 Sم ver‏ تکوین ال 1٥×‏ بشكل تصاعدي أو 
تنازلي. 


ملاحظة: لا یمکن تحدید ال P٤٥۲0 S٤D‏ لل .]nde×‏ 


:7.10 مثال تطبيقي‎ 
:B-Tree Non-Unique Index ùıgكت‎ 
CREATE INDEX ind HR test 
ON HR.TEST (FIRST) 
PCTFREE 30 
STORAGE (INITIAL 200K NEXT 200K PCTINCREASE 0 MAXEXTENTS 50) 
TABLESPACE INDX; 


لتکوين B-T ree Unique Index‏ أضف كلم UNIQUE‏ ب±= CREATE‏ مباشرة. 
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:CREATING BITMAP INDEXES 


لتكوين ٥×‏ لہ[ 814p‏ يجب إضافة كلمة 8B]۲ M4۲‏ الى جملة CREATE ]N( ٤×‏ التي تم 
استخدامها في المثال 7.10. يمكن تحديد الحجم المخصص من الذاكرة لتخزين الموص.)81 بتحديد 
العامل CREA E_BI[TMAP_ AREA SIZE‏ الذي قيمته في الحالة u1)‏ ء0 هو .8M8‏ 
بزيادة حجم قيمة العامل» يتم تكوين ال × ل1 بسرعة أكبر» ولكن ينصح باستخدام قيمة صغيرة اذا كانت 
البيانات المميزة (المختلفة) في ال مص داه قليلة جداً (بيانات مختلفة كبيرة = ذاكرة كبيرة). 


مثال تطبيقي 7.11: 


CREATE BITMAP INDEX ind HR _jobid 
ON HR.JOBS (JOB_ID) 
PCTFREE 30 
STORAGE (INITIAL 200K NEXT 200K PCTINCREASE 0 MAXEXTENTS 50) 
TABLESPACE INDX; 


مثال تطبيقي 7.12: 
يمکن تکوين re٤ [dex‏ 8-1 أو Bitm 4p ]ndex‏ عبر ال م1امومه باتباع الخطوات التالية: 


Standalone عڊر‎ Console Û ادخل الى‎ 

اضغط على اسم ال مء طه)ه( لكي تظهر نافذةاتظلي من.اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختياً4 S۷558‏ عوضاً عن إوصإه.. 

.Schema Manager J| + اضغط على‎ 

اضغط على مجلد [1٥×‏ ثم بواسطة الزر اليمين للفأرة(الختر من القائمة ٠٤و٠إC٤.‏ 

ادخل اسم ال ٥ہ[‏ وأختر ال 4ر٥‏ طءS؟‏ و ال ce‏ ےم ء٤۲۹61‏ من القوائم › ثم اختر ال Cum‏ 

أو ال ورہںاہC‏ المراد وضع ×deہ]‏ لھا من ائم .Table Columns‏ 

٠ه‏ لتكوين ءلم[ مو_B1‏ » ضع علامة داخل المربع الصغير (فوق زر ٠٤4٠إ))‏ بجانب كلمة 
.Bitmap‏ 

ه أختر باقي البيانات من القوائم الأخرى (Storage, Partitions, Options)‏ 

اضغط علی زر .٤۲٥4)٥‏ 
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:ALTERING INDEXES 


يمكن القيام بعدة مھمات باستخدام جم :ALTER INDEX‏ 


:Changing the Block Storage Parameters 


یمکن تغيير قيم بعض العوامل مثل 1۸×X1R۸۸8‏ ويمكن تغيير بعض عوامل جملة ال م عوإه)؟ مثل ال 
.MAXEXTENTS‏ 


مثال تطبيقي 7.13: 


ALTER INDEX ind HR_jobid 
MAXTRANS 250 
STORAGE (MAXEXTENTS 200); 


أو عبر ال م1مو ه٥‏ باتباع الخطوات التالية: 


.Sta n da167 êڻبع‎ °0 1501e ادخل الى ال‎ 

اضغط على اسم ال مء طه٤4((لكي.تظهر‏ نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع(إالتاكد من اختيار 84 S۷505‏ عوضاً عن إوإإه.. 

„Schema Manager J| + اضغط على‎ 

اضغط علی + ال ×deہ[.‏ 

اختر اسم المستخدم الذي يملك ال ×ء 1,4 المرادتغيير خواصها (مثل ۸) 

اختر اسم ال ل1 من النافذة اليمنى و اضغط ليها مزثين (أو بواسطة الزر اليمين للفأرة › اختر 
من القlئمة ."View\Edit Details"‏ 

٠‏ ادخل الى قائمة #عهإه)S‏ » وعدل البيانات ثم اختر رامم۸. 


:Allocating & Deallocating Extents 
يمكن اضافة و٤ )× الى مساحة ال >م لم[ بنفس الطريقة المستخدمة في إضافة )٥)×ع الى ال م[إطه1‎ 
بنفس الشروط. كما يمكن حذف وار م)×E فارغة غير مستخدمة من مساحة ال هل.1 بتعويض جملة ال‎ 
بالجملة التالية:‎ ۸ LL[0CA E EXTENT 

DEALLOCATE UNUSED [KEEP number [K|M]] 
في القاعدة:‎ 


.Unused Extents J| لإبقاء مساحة خالية من‎ :×EEP 
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مثال تطبيقي 7.14: 
لإضاغة Extent‏ : 


ALTER INDEX ind HR_jobid 
ALLOCATE EXTENT SIZE 200K; 


لحذف مساحة خالية (و٤ر٤)x٤):‏ 


ALTER INDEX ind_HR jobid 
DEALLOCATE UNUSED; 


:Rebuilding Indexes 


لنقل ال ٥×‏ ہ1 الی ٥cےم٥1ط‏ ھ۲ آخری أو لتغییر خواص ال $٥۲4 ۴۸۲4٥٥٤٥۲۶‏ یمکن استخدام 
REBUILD e LTER INDEX‏ كما توضح القاعدة: 


ALTER INDEX [schema.]Index name REBUILD 
[TABLESPACE tablespace_name] 

[PCTFREE number] 

[INITRANS number] 

[MAXTRANS number] 

[LOGGING | NOLOGGING] 

[REVERSE | NOREVERSE] 

[STORAGE (INITIAL SIZE [KM] NEXT SIZE [KIM] ....] 


في القاعدة: 
:REVERSE ®‏ يمکن تحویل ال ×11 الى نوع Reverse ey [n>‏ باضافة الجملة الى 
القاعدة. هذا النوع يعرف بيانات ال مصں‌اه٥‏ بشکل عکسي » مئل لو کان 0۲۵۲_15 يحتوي 
على الرقم 12345 فإن الأوراكل يعكس الرقم الى 54321 ویضیف ال رہ ںاہ الی ال .[,de×‏ 
هذا النوع بستخدم بالعادة مع ال ووصںآه المعرفة بياناتها بشكل تصاعدي» اذ يتم توزيع البيانات 
المتقاربة الى ئfهم.]‏ مختلفة ليتم تسهيل أخراج البيانات بسرعة أكبر. 
نتائج عملي Rebuild Index J|‏ : 
ه بعد انتهاء العلميةء يتم تكوين ٥×‏ ل1 جديد و حذف الأصلي» بحيث تساعد على تكوين ٠×‏ 1,0 جديد 
متكامل غير ال ×14[ الأصلي الذي قد يكون قد فقد جزء من مساحة نتيجة للتغيرات التي تطراً على 
ال Rs‏ مثل حذف البیانات و تجدید ها "٥,٤2 ٤10,(‏ عه۴۲) › وبالتالي استخدام وتخصیص 
المساحة بشكل أفضل. 
ه خلال العملية › يمكن لل وعمںQ‏ استخدام ال م [n‏ الأصلي. 


ملاحظة: لا یمکن استخدام 11ں ط8 لتغییر ال چم لم1 من 8-1۲۲ الى مةوص)81 أو بالعكس. 
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مثال تطبيقي 7.15: 
للقيام بعميلة [زںطءR‏ على ال ×هdم]:‏ 


ALTER INDEX ind HR Jobid REBUILD 
TABLESPACE INDX02; 


Rebuilding ONLINE 

أحياناً تستهلك عملية 14ں ط8 وقت كبير جداً عندما تكون ال م1طه٠‏ كبيرة جدأ. في السابق لم يكن بالمقدور 
القيام بمهمات ال ١1‏ على ال ماط هآ التي يجري عملية >مءلم] dازuطءR‏ على ×مdم1‏ مخصصة لها. 
في النسخ الحديثة من أوراكل (8٥1ءهإ0‏ و 91٥1ءهإ0)‏ يمكن أن تجري مهمات ال ]۷[ بينما تتم عملية 
Rebuild Index‏ بإضافة €INEاON‏ الی جانب ۰R E811‏ ولکن لا ینصح بالقیام بمھمات کبیرة 
ويفضل الاقتصار على المهمات الصغيرة. 


ملاحظة: لا يسمح بكل الأحوال القيام بمهمات ال 51 على ال م1ab1‏ خلاJ «Rebuild Index ÛJI‏ 


:7.16 مثال تطبيقي‎ 
?Tîn dex JI عل‎ Rebuild Online للقیام بعميلة‎ 


ALTER INDEXıind HR Jobid REBUILD ONLINE; 


:Coalescing Indexes 
.1مdه× بالقيام بعملية ءءم[aوهC٤ على ال‎ [4٥× یه۴ في ال‎ ٤:٤٤10 يمكن التخلص من أثار ال‎ 
ع۴۲۹ فأصبحت کل‎ ٥,٤4٤1٥٣۸ کما يبدو في الرسم ۰7.2 وجود 2 ھم[ تعرضتا لعملیات ادت الی حدوث‎ 


واحد منهما نصف ممتلئة. ولكن بعد حودث عءءء1ه0) تم دمج النصفين مع بعضهما مما نتج عن وجود 
1۴ فارغة تماما. 


و 


رسم 7.2 


122 


مثال تطبيقي 7.17: 
للقيام بعملية gرiء‏ ءء021٤‏ لل :Index‏ 


ALTER INDEX HR.ind hr _ jobid COALESCE; 


:Identify Unused Indexes 


یمکن وضع ×ملہ] تحت المراقبة لمعرفة اذا کان یستخدم م ل وبالتالي حذفه في حال عدم استخدامه. یتم 
جمع المعلومات حول ال ×ع د1 المراقب في .V$OBJECT_ USAGE‏ 


ملاحظة: كل مرة يتم فيها مراقبة ال ×ملم!] › يتم إلغاء البيانات السابقة لل مم1 في 
.VŞOBJECT_ USAGE Û‏ 
مثال تطبيقي 7.18: 
لوضع ال ×م لم[ تحت المراقبة: 
ALTER INDEX HR.ind_hr jobid MONITORING USAGE;‏ 
لوقف مراقبة ال م dم]:‏ 


ALTER INDEX HR.h hf jobid NOMONITORING USAGE; 


:ANALYZING INDEXES 
للقیام:‎ ۸N۸ 1۷7€ ]N 5٤× یمکن استخدام جملة‎ 


٠ه‏ التأكد من أن ال وم81 الخاصة بال >م لم[ لا تحتوي على بيانات فاسدة " )810 
.""Corruption‏ 


٠‏ للحصول على معلومات حول ال ×مأم[. 


بعد القیام ب ]N5( ٤×‏ ۸۸1۷7۴ یتم تخزین معلومات حول ال ملم[ في س۷1 اسمهھ 

NDEX_ STATS‏ | ۰ یعرض هذا ال ۷1W‏ معلومات عن عدد ال وع ٥ا8‏ وعدد ال وع م81 المستخدم 
ولكن أهم من ذلك هو رقمي کل من 80⁄١ W S8‏ ۴°[ و DEL L۴ N R0⁄١ W8‏ ۰ بحیث اذا زادت النسبة بین 
الرقمين عن 30% (مثلاً الرقم الأول يساوي 50 والثاني يساوي 100 فهذا يعني النسبة %50) فهذا يعني 
أن ال xم‏ ہ1 تعرض لحذف بیانات "R٥ Ws"‏ کثیرة مما قد ینتجھ عن ٤1٥۸‏ ٤۸ہ‏ عھا۴ في ال ×deہ1.‏ 
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مثال تطبيقي 7.19: 
للقيام بعملية y7e[ھ‏ م۸ لل ×eلn][:‏ 

ANALYZE INDEX HR.JOB_ID_PK VALIDATE STRUCTURE; 
:1N(5٤×X_ $1۸18 بعد ذلك استخرج المعلومات من‎ 


SELECT BLOCKS , PCT USED, LF_ROWS, DEL LF ROWS 
FROM INDEX STATS; 


يظهر في جهازي الناتج التالي: 
BLOCKS PCT USED LF ROWS DEL LF ROWS‏ 


0 19 9 16 


وكما تلاحظ النسبة بين الرقمين لا تتجاوز ال 30%. 


:DROPPING INDEXES 


عند عدم الحاجة لل ×م لم[ أو عند حدوث خلل له أو عند تحول حالة ال ×م م1 الى 1.۷۸15 بسبب 
حدوث خلل لل مہ ووم[ › یمکن حذف ال [de>‏ ڊواسطة جأ .DROP INDEX‏ 


ملاحظة: لا یمکن حذف ال e>‏ لہ[ اذا کان Unique KÊY Primary Key‏ ولديە علاقة مغ .FK‏ 


مثال تطبيقي 7.20: 
لحذف ×eلہ]آ:‏ 

DROP INDEX hr.ind hr jobid; 
أو عبر ال م1مو ه٥ باتباع الخطوات التالية:‎ 


ادخل الى ال s01¢ئCon‏ عڊڙر .Standalone‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷S584‏ عوضاً عن إومإه.. 
اضغط على + .Schema Manager J|‏ 

اضغط على + ال .]"d ٥×‏ 

اختر اسم المستخدم الذي يملك ال ×مإم!] المراد حذفه (مثل )§R‏ 

اختر اسم ال 1٥×‏ من النافذة اليمنى و بواسطة الزر اليمين للفأرة › اختر من القائمة 
("Remove"‏ أو من القائمة الأساسية› .Remove pۃ؟û Objec†‏ 

اختر ی۷6. 
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:QUERYING INDEX INFORMATION 
للحصول على معلومات حول ال ×ع ل[ یمکن استخدام:‎ 


DB A_]NDEXES‏ : يوفر معلومات عديدة مثل اسم ال ×[ ونوعه واسم ال 1۲ط التي 
ينتمي لها ال ×11 واسم المستخدم الذي يملك ال لم1 وخواص ال #عه4١٥5)0‏ وغيرها. 


°01 واسم ال‎ [dex یوفر معلومات عدیدة مثل اسم ال‎ :DBA_]ND_C0LUMNS 
التي وضع عليها ال ×م ل1 وخواص ال مص ں1٥٥ وغيرها.‎ 


.Function-Based Indexes J| J> ڍر لومت‎ :DBA_IND_EXPRESSIONS 
يوفر معلومات ناتجة عن عملية ×م لہ[ g«ذاەtن«10[. يوفر‎ : ۷50B EC_USAGE 
لم] واذا ما کان‎ ٥× التي ينتمي لھا ال‎ ٣٣ ط1٥ معلومات حول مثل اسم ال ×[ ونوعه واسم ال‎ 


یحری عملیة چرذه†¡ M0‏ علی ال × ۵ہ[ ام لا ( 05٤5‏ التي تدل علی اذا ما کان تم استخدام 
ال مم1 خلال المراقبة )» وقت بداية وانتهاء المراقبة "عمiا İt‏ م ."Mo‏ 
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MANAGING CONSTRAINTS 


يمكن وضع قوانين على ال )د0 (مثلاً عدم السماح بوجود بیانات متشابه في ٣ہ‏ ں[٥٤)»‏ باستخدام کل من 
.Integrity Constraints sy «+ Database Triggers + Application Code‏ 

ال Application Code‏ عبارة عن برمجة كود محدد (مثل برمجة الجافا) يعمل كبرنامج لوحده في ال 
C1ient‏ أو من ضمن ال ۲ط وھ( علی شکل .۴٣٥ ٤٤4 ue‏ اما ال Database r1gg es‏ فهي برامج 
من تكوين [@ ۲1/8 › يتم تنفيذها عند حدوث مهمة محددة في ال موو طه)ه( مثل القیام ب 1S٤‏ أو 
UPDATE‏ . 


:INTEGRITY CONSTRAINTS 


يفضل استخدام هذا النوع عن النوعيين الأخريين لسهولة تكوينه وتعديله › ولسهولة تشغيله أو وقف تشغيلهء 
ولإمكانية استخراج معلومات عنه من ال راو" ٠ا51‏ و0at.‏ يوجد عدة أنواع من Integrity J|‏ 
Constraint‏ ھي: 


:NO1 NULL‏ يحدد أنه لا یمکن لل ر" ں1ه٤‏ أن یحتوي علی (N01‏ کل ال 8٥ Ws‏ یجب أن 
U N]QUE‏ : تحدد أن القیم الموجو 3ۃ ف ال مہ ںاہ (أو آکثر من دہ ںاہ٤)‏ ممیزة ولا یمکن 
أن تتشابهء يستخدم هذا النوع عادق د تخصيص رقم مميز لكل موظف في الشركة. يسمح ال 
U} N]QU£‏ باستخدام قیم 1 ا N‏ في ال .R 0 ws‏ 

Primary Key Û! ya (Column ja )و أکأر‎ ColuînıîÛا‎ jİ تد‎ :PRIMARY KEY 
في ال رہ ںuاہC وعدم‎ R٥ Ws في ال 1۲ط ۲. تکون مهمة ال ×۴ بضمان تم تشاب بیانات ال‎ 
.N"ا1‎ 1 على قيمة‎ 80s إحتواء ال‎ 

FOREIGN KEY‏ : تحدد أن ال 01u نھارثکأ٣وأ( Colum‏ ) ھو F0 eig„ Key‏ في ال 
rabe‏ »› یتصل مع ۴P‏ أو ¡ue‏ € في ال ۲41e‏ أى في م۲41 أخری. 

:CHECK‏ تحدد قانون یجب علی کل ال وس80 تنفيذه#(مثل أن يكون قيم ال 8٥۷s‏ الخاصة 
بجنس الإنسان» إما M1‏ أو ۴ › ولا يمكن ادخال أي بيانات#أخذى). 


:Integrity Constraints JI تٺںلlھ‎ 


يمكن وضع ال كمذوإ٤وره٤‏ في أربع حالات تؤثر على البيانات المخزنة في ال م[اطه1 والبيانات الجديدة 
التي سوف يتم ادخالها مستقبلاً: 


:DISABLE NOVALIDATE‏ في حال وص Constraint Û‏ في هذه الحالةء لا يتم فحص 
البيانات الموجودة ولا يتم فحص البيانات المستقبلية لمعرفة اذا كانت تتطابق مع القانون أو الشرط 
الذي يحددo .Constraint J|‏ 

D1SA BLE ۷ ALIDA TE‏ : یتم ایقاف عمل ال ٤ہ‏ )یرہ٥٤‏ وحذف ال ×۵ ہ] المخصص لھا 
وعدم السماح بالقيام بأي تعديلات على البيانات المخزنة (عدم السماح بعمليات ا0DM).‏ 
ENABLE NOVALIDATE‏ : لا يتم فحص البيانات المخزنة لمعرفة اذا ما كانت تتطابق مع 
قانون ال ٤٣ذھ۲‏ )وره و لکن لا يسمح بادخال بيانات جديدة تتعارض مع ال "٤‏ 41٣)ءىهC€.‏ 
ENABLE ۷ ALIDATE‏ : يتم فحص البيانات الجديدة والبيانات المستقبلية والتأكد أنها تتطابق 
مع ال ٤ہذھاtوره).‏ في حال وجود بیانات لا تتطابق مع ال ٤ہ۲1٤ءہ٥)‏ فیجب حذفھا أو تغییرھا 


وإلا لا يمكن الدخول الى هذه الحالة. 
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ملاحظات: 

1- لا ينصح التحويل من الحالة الأولى أو الثانية مباشرة الى الحالة الرابعة › اذ أن ذلك يؤدي الى عمل 
0cksا‏ علی کل ال 1eطھ۲‏ مما قد يؤدي الى تأخر انجاز مهمات ال 0[11/ لذلك ينصح بالتحويل الى حالة 
Enable Novalidate‏ أو قبل التحويJ .Enable Validate Û‏ 


2- عندما یتم تحویل Cons) a1٤‏ تستخدم Primary Key‏ أو Unique Key‏ من حالة eاEnab‏ الى 
حالة ماهو » فان ال ×م 1.0 الموجود يتم حذفه والعكس صحيح. 


3- التحول من حالة Enable Novalid ate‏ الى حالة Enable Validate‏ › ¥ يوقف عملیات ال 551. 


:CONSTRAINTS CHECKING 


يمكن لل s٤رذوإ٤وره)‏ أن يقوم بفحص البيانات المدخلة الى ال ماطه إما عند نهاية كل مهمة من مهمات 
ال DM1‏ و يسمی في هذہ الحالة Nonde ferred‏ أو ]mmediate‏ › أو يمکن لل s)مذھاstمهC‏ أن يقوم 
بفحص البيانات عند كتابة اص C٠‏ (قد يشمل مجموعة من المهمات) ويسمى في هذه الحالة أ١٠۲إءfء0›‏ 
في كلتا الحالتين يتم عمل kءوط11ه 8R‏ للمهمات التي انجزت اذا لم تتوافق مع قانون ال ٤"۲41)ء"هC€.‏ 
يفضل استخدام الحالة الثانية التي تنقسم الى قسمین بحيث تستطیع أن تشابه الحالة !مء N0”‏ والحالة 
Deferred‏ معاًء القسسین هما: 

.Nondeferred ÛJI Jمعک تعمل‎ NALLY IMMEDIATE 

.Deferred J| تمل کمل‎ N [T1 LLY DEFERRED ° 


لوضع ال ٤«ذدإ٤ءه)‏ في احدى الحالتين يت استتتخدام القاعدة التالية: 
SET CONSTRAINT | CONSTRAINTS‏ 
(constraint_name | ALL)‏ 
(IMMEDIATE | DEFERRED)‏ 
يمکن أيضاً استخدام 1ER SESS10۸‏ ۸ كما في القاعدة (تعمل في ال «هزووم؟ المحدد فقط): 


ALTER SESSION 
SET CONSTRAINTS] = ((MMEDIATE | DEFERRED | DEFAULT) 


مثال تطبيقي 7.21: 
لتغيير حالة کل :Deferred Jil Constraints JI‏ 


SET CONSTRAINTS ALL DEFERRED; 
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:CREATING CONSTRAINTS 


يمکن تكوين ال ٤s‏ م .ALTER TABLE ûl gyi CREATE TABLE ةlaج مIدختساب Const a1‏ 
يمكن تكوين ال )مها )ءره٤‏ في ال 1e۷e1-«صuاهC‏ أو في ال امء۷٥1-ء1ط14‏ على أن الأخيرة تسمح 
بتکوین ال ٤"1ھ۲‏ یمه لأکثر من رص ں1٥٥‏ واحد وهذا لا تسمح به الأولى. 

يجب أن يكون للمستخدم REFERENCES Privilege‏ اللازمة لكي يستطيع تكوين وخم ذة۲٤یء«هC‏ في 
Shen‏ أخرى غير ال $1٥4‏ الخاص به. 


:Column-Level JI في‎ Constraints لتكوين‎ 


CREATE TABLE table_name 

(column_name TYPE [CONSTRAINT constraint name] C1 | C2 | C3 | C4| C5) 
[NOT DEFERRABLE | DEFERRABLE [INITIALLY (IMMEDIATE | 
DEFERRED)] |] 

[DISABLE | ENABLE [VALIDATE | NOVALIDATE] 


أما ال °4 ,°3 ٤C1, ٤2,‏ فهي أنواع ال sئCons)raİnÉ:‏ 


[NOT] NULL =C1 

UNIQUE [USING INDEX ....] =C2 

PRIMARY.KEY [USING INDEX...] =C3 

REFERENCES [schema.] table name [(collnmuf name)] [ON DELETE =C4 
CASCADE] 

CHECK (condition) =C5 


اما جملة US1N6 1ND5٤×‏ فهي تتطابق مع جملة CREATE 1ND ٤%‏ عدا استخدام U S1N6‏ عوضاً 
peg «ON [schema.]TABLE (Colym/[ ASC | DESC] ءjجll دıدحت pes CREATE jE‏ 
ذکر اسم ال ×deہ[.‏ 


في القاعدة: 


:0N DELETE CASCADE °‏ تضمن حذف البیانات المرتبطة في ال C114‏ بواسطة ۴K)‏ مع 
ال Parent‏ (راجع الأمتحان لٺJg .(Introduction to SQL‏ 


مثال تطبيقي 2.22: 
لتكوين Constraints‏ ي :Column-Level ÛI‏ 


CREATE TABLE hr.new_emp ( 

Emp_id NUMBER(8) CONSTRAINT new_emp_id pk PRIMARY KEY 
DEFERRABLE INITIALLY DEFERRED 

USING INDEX STORAGE (INITIAL 100K NEXT 100K) TABLESPACE indx, 
Emp_Name VARCHAR2(20) CONSTRAINT new_emp_name NOT NULL, 
Salary NUMBER(10) CONSTRAINT new_emp_ck CHECK (salary >0) 


J: 


128 


:Table-Level JI في‎ Constraints لتكوين‎ 


CREATE TABLE table_name 
(column_name TYPE , column name TYPE, ...., 


[CONSTRAINT constraint _ name] 

PRIMARY KEY (column_name , column name, ...) [USING INDEX ....] 

| UNIQUE (column _ name , column_name, ...) [USING INDEX ....] 

| REFERENCES [schema.] table_ name [(column_ name, column name, ...)] 
[ON DELETE CASCADE] 

| CHECK (condition) 


[NOT DEFERRABLE | DEFERRABLE [INITIALLY (IMMEDIATE | 
DEFERRED)] ] 

[DISABLE | ENABLE [VALIDATE | NOVALIDATE] 

J 


.Column-Level Û ف„‎ ¥! NOT NULL.Co straint ùيوكت ملاحظة: لا یمکن‎ 


مثال تطبيقي 223 
لتكوين Constraints‏ في :Table-Level JI‏ 


CREATE TABLE hr.new_emp 

( 

Emp_id NUMBER(S) 

Dept_id NUMBER (8) 

Emp_Name VARCHAR2(20) CONSTRAINT new_emp_name NOT NULL, 
Dept_name VARCHAR2(20), 

Salary NUMBER([10), 

CONSTRAINT new_emp_id pk PRIMARY KEY (Emp_id, Dept id) 
DEFERRABLE 

USING INDEX STORAGE (INITIAL 200K NEXT 200K) TABLESPACE indx 
CONSTRAINT new_emp_ck CHECK (salary > 0) 

) 


ملاحظة: لتکوین ٤ہ‏ ه۲٤ءمهC‏ عبر ال مامه اتبع خطوات تكوین ال م1ط ه٠‏ مع التأكد من ادخال 
البيانات في القائمة sامذaا†sىC0.‏ 


تذكر: يفضل توزيع ال وم×م ل[ الى عمcومءء1ط۲a‏ مختلفة عن ال .14([e‏ 
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:USING ALTER TABLE 


يمکن استخدام جملة LER TA BLE‏ ۸ لتکوین أو تعدیل حاlة .Constraints J|‏ 


:Creating Constraints 


کما ذکرنا قبل قلیل أنه یمکن تکوین s٤ہ1ھ٣٤ء٬ C٥‏ باستخدام CREATE TABLE‏ أو باستخدام جملة 
۸L" ER TABLE‏ كما في المثال 2.24. 


:2.24 مثال تطبيقي‎ 
:ALTER TABLE ةطmlgڊ‎ Constraints ةغlضإل‎ 
ALTER TABLE hr.new_emp ADD 
Si new_emp_id_fk FOREIGN KEY (Dept_id) 


REFERENCES hr.departments (id) 
DEFERRABLE 


): 


لا يمكن تطبيق هذا المثال على ال N01 ١01‏ › اذ يستخدم التالي لإضافة ٤مزوإء«ه٥‏ من هذا النوعء 
أو للتحويJ NULL sy NOT NULL ju‏ 


ALTER TABLE hr.new_emp MODIFY.Dept_ name NOT NULL; 


:Enabling Constraints 
.ALTER TABLE pIڍختwlڊ‎ Enable Jll Disable ja Constraint Û| يمکن تحويل حال‎ 
‘Enable No validate 


يفضل التحويل الى هذه الحالة أولاً قبل التحويل الى اllaÛة JI y Unique Constraints Jİ Validate‏ 
PK Constraints‏ لأن ذلك يؤدي الى عمل )م1 على كل ال ۲11۲ مما قد يؤدي الى تأخر انجاز 
مهمات ال ]¥[ مما يؤدي الى تأخر عملية التحويل. تستخدم القاعدة التالية للتحويل من حالة مء[إطدء5 
ئ .Enable Novalidate ll‏ 


ALTER TABLE [schema.] table_name 

ENABLE NOVALIDATE {CONSTRAINT constraint name | PRIMARY KEY | 
UNIQUE (column , column2, ....) } 

[USING INDEX.....] 


بحيث يتم اضافة جملة 1N( ٤×‏ S1N6ا‏ في الحلات التي یتم فیھا تحویل حالة ال ٤ہ¡ P× Cons)‏ أو 


ال Unique Constr ain‏ فقط ويحب أن تكون الحالة التي تم تكوينهم في البداية ماطه٣إءfء0‏ ويجب أن 
يكون ال مل .[ الذي تم تكوينه في البداية إما ل٥1طهوا‏ أو تم حذفه. 


10 


-Lnable Validate 


هي الحالة الإفتراضية "٤[ں‏ وء(" التي يتم فيها التحويل من ال م1طهءا الى ال ماطه"٤.‏ بعد عملية 
التحويل يتم فيها وضع ].0cks‏ علی البيانات حتى تنتهي عملية فحص البيانات الموجودة» وفي حالة عدم 
وجوذ PK, UNIQUE Constraints Û [Indexes‏ » يقوم ال Server‏ eاOrac‏ بتکوین [dex‏ من نوع 
Non-U nique‏ اذا کان قد تم تکوین ال s٤مذهوم‏ ه٥‏ في البداية بالحالة 1۲ ه٣إ٠۴ء(‏ والعكس صحيح اذ 
یقوم ال Orac1e Server‏ بتکوین e×‏ لہ[ من نوع ue‏ 1ہ ا اذا کان قد تم تکوین ال sمذھاtووه٥‏ في 
البداية بllÛة .Nondeferrable‏ 


تستخدم ذات القاعدة التي تستخدم للتحويل من حالة 1ط aوء1(‏ الى حالة Enable Novalida†e‏ مع استبدال 
Validate) A LIDATE ûn NOVALIDATE nl‏ هي ال {اDefau)‏ وإمكانية إضافة جملة 
٤۴× CEP [58‏ التي سوف نتطرق لھا بعد قلیل. 


مثال تطبيقي 2.25: 
لتحويل الحالة الى :N0va11d ate‏ 


ALTER TABLE hr.new_emp 
ENABLE NOVALIDATE CONSTRAINT new_eînp_id_pk; 


لتحويل الحالة الى م٤‏ لiاو۷:‏ 


ALTER TABLE hr.new_emp 
ENABLE VALIDATE CONSTRAINT new_emp_id_pk; 


لتحويل الحالة باستخدام ال e[مورهC:‏ 


ادخل الى ال C001‏ عیبر .Standalone‏ 

اضغط على اسم ال مءطهه( لكي تظهر نافذة تطلب من اسبم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاکد من اختيار 6۸ S۷55‏ عوضاً عن إوصإه.. 

.Schema Manager J| + اضغط على‎ 

اضغط على + ال .٣(1۲‏ 

اختر اسم المستخدم الذي يملك ال ٥1ط‏ ه۲ المراد تغيير خواصها (مثل #۸) 

اختر اسم ال م1ط ۲1 من النافذة اليمنى و اضغط عليها مرتين (أو بواسطة الزر اليمين للفأرة › اختر 
من القlئمة ."View\Edit Details"‏ 

٠‏ ادخل الى قائمة و٤مذھا٤یره٤‏ › ثم عدل البیانات ثم اختر رامم۸. 
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:USING EXCEPTIONS 


تستخدم جملة ال ۲۲108 5×۳٤‏ لمعرفة البيانات التي تخالف ال و٤رذوإ٤ورهC‏ بعرض معلومات حول 
ال البيانات "R0 Ww"‏ المخالفة لل .EXCEPTIONS Table Jaصت Table يفû Constraint‏ 


للقیام بفحص البیانات قبل القیام بتحویل ال ٣41۸٤‏ )ء"ه٥‏ من حالة ٥1ط‏ ء1( الى مهمع يمكن اتباع 
الخطوات التالية: 


تکوین ال 1۲ا۹٣‏ ء«منامpمExc ١‏ اذا لم یتم تکوینها من قبل بتشغیل S٤‏ هو ای.٤‏ مu)]e×c‏ 
من داخل ال 5ا1۲ :58Q‏ 


@ C:\oracle\lora90\rdbms\admin\utlexcpt.s ql 


تحویل ال Constr ai)‏ الى Enable Validate‏ بإضافة الجملة التالية اى ALTER‏ 
:TABLE‏ 


EXCEPTIONS INTO system.exceptions 


ه في حال ظهور اخطاء تمنع من تحویل حالة ال Cons) 1٤‏ الى Enable Validate‏ استخدم 
المعلومات التي تكونت في ال ٥1ا14‏ ٤nہ٥نامExcep.‏ 


SELECT * FROM tablıfame 
WHERE ROWID IN (SELECT ROW “ID FROM EXCEPTIONS); 


„UPDATE TABÎF ط¦¡l اجراء تعديل للبيانات المخالفة بو‎ ٠ 


.ALTER TABLE lil Enable Validate Jll Constraint J| Jıgy<î 


:OUERYING CONSTRAINTS INFORMA TION 
للحصول على معلومات حول ال s٤٢ذھ ۲٤وره یمکن استخدام:‎ 


:D(BA_)C0NSTRAINTS‏ يوفر معلومات عدیدة مثل اسم ال "4ء ونوعه والحالة 
التي يوجد فيها وغيرها من المعلومات. 


:D(BA_C0NS_COLUMNS °‏ یوفر معلومات عدیدة حول ال ود ں1٥٥‏ التي وضع علیھا ال 
.Constraints‏ 
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اذہل الثامم 


إدارة! البو ززز و باسورد 
سیصضور ني و الریسور سيس 


Managing USERS & password 
SECURITY& RESOURCES 


PASSWORD MANAGEMENT 


:PROFILES 


یستخدم ال ع[زگم P٣‏ للتحکم بال 0d‏ wویھ۴‏ وال ۶٥ں‏ ٥ء٥8‏ بواسطة ال 8۸( عبر تحدید عوامل 
"Parameters"‏ خاصة بال 1اه ۴› من الأمور التي يمكن التحكم بها مثلاً أن يمنع بعض المستخدمين من 
اجراء مهمات محددة أو إخراج المستخدم من ال Database‏ اذا لم ينفذ مهمات لوقت محدد. عند تکوين ال 
Database‏ › يقوم ال Sever‏ eاOrac‏ بتکوین ال ۴۲٥11٥‏ ٤[uهfء(‏ الذي يخصص لجميع المستخدمين ما 
لم یتم تکوین ۴٥۴11٥‏ جدید(کل القیم في ال ۴٥۴1e‏ ٤اںهfء0‏ تساوي 4٥)نصذاہا).‏ یمکن آن یخصص 
"Assign"‏ ال eاProfi‏ لل Users‏ فقط ولا یمکن تخصیصہ لل و٥1٥8‏ أو ٥1ا٣۴‏ أخریء ولا یؤثر 
تخصیص ال ۴۲٠۴11٥‏ على ال «هإووم؟ الحاليةء اذ يجب خروج المستخدم ثم دخوله مرة أخرى الى ال 
)هط لکي تنفذ حدود ال ٥1ا۴‏ ۴. یتم تخصیص ال ۴٣٥۴1٥‏ لل ومول باستخدIم‏ جأ CREATE‏ 
.ALTER USER gy USER‏ 


ملاحظة: يمكن اغلاق وتشغيل ال .(Enable, Disable) Profi]‏ 


‘MANAGING PASSWORD 
بالتحکم بال 0۲۹۵ wWھP باستخدام ال eاگہ ظ٥ یمکن:‎ 


ه تحديد عمر محدد لكلمة السر "١١0س‏ وجب على المستخدم تغييرها بعد انتهاء المدة. 

° إجبار المستخدم على اختيار كلمة سر معقدة تتبعرنظام محددة (مثلاً أن لا تتشابه كلمة السر مع اسم 
المستخدم) 

ه اجبار المستخدم عند تغيير كلمة السر عدم اختيار كلمة شر تم استخدامها سابقاً. 

اغلاق ال ٤ں‏ ء۸ الخاص بالمستخدم عند فشل ادخال#كلمة السر لعدد محدد (مثل فشل ادخال كلمة 
السر لثلاث مرات). 


:Locking Account 


یمکن غلق ال )nړAccou‏ بشکل اوتوماتیکي عند فشل الدخول الى Account Û‏ عند كتابة كلمة سر خاطئة 
لعدد من المرات» كما يمكن تحديد المدة التي يظل فيها ال ٤م‏ uهءء۸‏ مغلق عبر تحديد العاملين التاليين: 


:۴۸1LED_L0GING_ATTEMPTS *‏ عدد المرات التي يسمح فيها ادخال كلمة سر خاظئة 
قبل أن يتم غلق ال ٤uهءء4»‏ مثل آن تحدد القيمة بثلاث محاولات وبعد المحاولة الثالثة يغلق ال 
.Account‏ 

:۴SSWORD_LOCK_TIME °‏ تحدد قيمته المدة التي یظل فیھا ال u۲‏ ٥ء٥۸‏ مغلق› وبعد 
انتهاء المدة يفتح ال ٤‏ ںهءء۸ بشكل آوتوماتيکي (مثلاً بعد 3 أيام). 


کما یمکن لل 8۸( غلق ال ۸٥٥٤‏ أو فتحه باستخدام جملة 11۲٤۸ 0S۴‏ ۸» في حالة غلق ال 
ccount‏ بواسطة ال D8۸‏ لا یمکن فتحھ أوتوماتیکیاً بل یجب أن یتم فتحھ عبر ال 8۸( فقطہ 
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:Password Expiration 


يمكن تحديد المدة التي یجب على المستخدمين تغيير كلمة السر 0۲d"‏ wووءھو۲'‏ بشكل دوري› کأن یجبر 
المستخدميين تغيير كلمة السر كل شهر. يمكن ايضاً اعطاء مهلة اضافية عند انتهاء المدة التي يجب تغيير 
كلمة السر » بحيث بعد دخول المستخدم الى مءدطهاه0› يظهر رسالة تحذيرية تطلب من المستخدم تغيير 
كلمة السر خلال فترة محددة وإلا سوف يتم غلق ال "٤‏ uهء۸.‏ 


:SSWORD_LIFE_TIME °‏ المدة التي يمكن لكلمة السر أن تظل دون تغييرء في حال عدم 
تغيير كلمة السر خلال المدة يغلق ال u٤‏ هءء۸ وتتحول حالة اÛ .Expired Jll Account‏ 

:SSWORD_GRACE_TIME °‏ بعد ان تنتهي المدة التي يمكن لكلمة السر أن تظل دون 
تغيير» يمكن اعطاء مدة إضافية لتغيير كلمة السر قبل غلق ال )سهءء۸ مع ظهور رسالة تحذيرية 
لتغيير كلمة السر قبل المدة المحددة. 


مثال: 


عiد‏ تحدıد ao PASSWORD_LIFE_TIME ÛJI‏ ش4ر ۾g PASSWORD_GRACE_ TIME‏ 
بمدة ثلاثة أيام يحدث التالي: بعد انتهاء الشهر دون تغييير كلمة السر وكلما دخل المستخدم الى ال Acco‏ 
تظهر رسالة تحذيرية تطالب المستخدم من تغيير كلمة السر خلال 3 أيام وإلا سوف يتم غلق ال .Accoun†‏ 


:Password Histor 


يمكن اجبار المستخدم على اختيار كلمة سر لم تستخدم رمن قبل أبداً أو منعه من استخدام كلمة سر قديمة خلال 
فترة محددة. 


:ASSWORD_REUSE_TIME‏ تحدد عدد مز(الأيام قبل أن يتم اعادة استخدام كلمة سر 
قديمة مرة أخرى. 

:SSWORD_REUSE_MAX‏ تحدد عدد الماترالتي یمكن ان يتم استخدام كلمة السر 
القديمة. يمكن اجبار المستخدم بعدم استخدام كلمة سر قديمة أبدا بوضع قيمة العامل صفر. 


ملاحظة: لا يمكن تحديد قيمة للعامليين معا ابداًء اذا تم تحديد قيمة أحد العامليين يجب وضع قيمة الأخر 
.Unlimited‏ 


:Password Verification 


يمكن وضع قوانيين لتسمية كلمة السر باستخدام .۲1/8Q1‏ من القوانيين التي يمكن تحديدها أن لا تكون 
كلمة السر مطابقة لإسم المستخدم أو يجب أن تحتوي كلمة السر على أرقام و أحرف معا وكل ما يساعد على 
تكوين كلمة سر معقدة يصعب التكهن بها. 
:PASSWORD_VERIFY_ FUNCTION °‏ لتحدید اÛ P/Q Function‏ التي سوف 
تستخدم في وضع قوانيين على اختيار كلمة السر. 


ملاحظة: یجب تکوین ال ہهناcىں۴‏ في ال ھر eط›؟ S۷58‏ › ویجب ان تکون من نوع ۰801٥41‏ أي أن 
الناتج اما صح 'eں "۲٣‏ أو خطاً "eء[ھ۴''.‏ 
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یوفر Oracle Server Û‏ ضمن ال q1ئٍ.utlpwdmg‏ « ERIFY_FUNCTION‏ ۷ التي یمکن ان 
تستخدم لوضع قوانيين لكلمة السر اذا تم تحديدها في .PASSWORD_VERIFY_ FUNCTION‏ 


:VERIFY_FUNCTION J! jڍıنlgق‎ 


ه أن لا يقل حجم كلمة السر عن اربع خانات» وأن يكون من ضمنها على الأقل حرف واحد ورقم واحد و 
رمز خاص واحد مثل $. 

ه أن لا تتطابق كلمة السر مع اسم المستخدم. 

ه أن تختلف كلمة السر الجديدة عن التي قبلها على الأقل بثلاث خانات» مثلاً لو كانت كلمة السر القديمة 
هي 8$ N1‏ › فلا تقبل كلمة السر الجديدة اذا كانت N1753‏ على اعتبار وجود اختلافيين اثنين فقط 
هما (3,7). 


:CREATING PROFILE TO MANAGE PASSWORD 
لإدارة ال ١إ0سوءه۴ باتباع القاعدة التالية:‎ ۴۴11٥ یمکن تکوین‎ 


CREATE PROFILE profile name LIMIT 

[FAILED LOGING_ATTEMPTS number] 

[PASSWORD_ LOCK TIME number _ of days] 

[PASSWORD_LIFE TIME number _of day] 

[PASSWORD_ GRACE _TIME number of dãyš] 
[{(PASSWORD_REUSE_TIME | PASSWORD REUSE_MAX} 
number of days] 

[PASSWORD_VERIFY_ FUNCTION {fmnction name | NULL | DEEAULT}] 


في القاعدةء 


:)PASSWORD_REÛE_TIME | PASSWORD_REUSE_MAX}‏ جمع العاملیین 
بين إ ) يدل على السماح بوضع قيمة لأحدهما ولا یمکن”لگليهما كما تم ذكره مسبقاً. 
٠‏ يمكن وضع القيمة .(number_of_days «number) jz Îضge UNLIMITED‏ 


ملاحظة: كل العوامل اختيارية واذا لم يتم كتابتها يؤخذ القيمة ال )[uه؟ء0‏ وهي لء)iصiاnا.‏ 


مثال تطبيقي 8.1: 
لتکوین ۴۴1٥‏ للتحكم بكلمة السر : 


CREATE PROFILE myprofile LIMIT 
FAILED _ LOGING_ATTEMPTS 3 
PASSWORD_LOCK TIME 5 
PASSWORD_LIFE_ TIME 15 
PASSWORD_GRACE_TIME 7 
PASSWORD_REUSE_TIME 15 
PASSWORD_VERIFY_FUNCTION verify_function; 
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ملاحظة: لاستخدام الساعات أو الدقائق عوضاً عن الأيام تستخدم القيمة 1/24 للدلالة على يوم واحد ويستخدم 
0 للدلالة على دقيقة واحدة. 


لتحویل ٥۴٥۴1٥‏ باستخدام ال 01یو :٤٥‏ 


ادخل الى ال .Standalone رڊعe Console‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S584؟S۷$‏ عوضاً عن إوصرإه.. 

.Security Manager J| + اضغخط على‎ 

اضغط بواسطة الزر اليمين للفأرة على مجلد ال ماا؟ه ۴ واختر من القائمة التي تظهر ٥٤4٠إ°.‏ 
في النافذة الجديدةء ادخل اسم ال ٥ان؟ه۲.‏ 

ادخل الى قائمة 0U‏ wوووP‏ وادخل البیانات التي ترید. 

اضغط علی ٥)4٥إC٤.‏ 


ملاحظة: سوف يأتي لاحقاً كيفية تخصیص P۲۴11]‏ للمستخدم "مل ". 


:ALTERING PROFILE 


يمكن تغيير قيم العوامل باستخدام جم ۸L ER PROPILE‏ › كما في المثال 8.2. 


مثال تطبيقي 8.2: 


ALTER PROFILE mypro file 
FAILEDALOGING_ATTEMPTS 2 
PASSWORD:LOCK_ TIME UNLIMITED 
PASSWORD_LIFE_TIME 10 
PASSWORD_GRACE_TIME 7/24 
PASSWORD_REUSE_TIME 10 
PASSWORD_VERIFY_FUNCTION verify_function; 


أو باستخدام ال م01یى٥٤:‏ 


ادخل الى ال 01e‏ "°0 عېبر .Standalone‏ 

اضغط على اسم ال مءطه)ه( لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 S۷50‏ عوضاً عن إوإإه.. 
اضغط على + .Security Manager J|‏ 

اضغط علی + ال ع۴1٥٥‏ واختر اسم ال م1گه۴ المراد تعديله. 

تظهر الخواص في النافذة الیمنی› عدل البیانات القائمة ۴۳0۲۵ ثم اضغط علیرآم‌م ۸ . 


ملاحظة: التعديلات التي تحدث لل ٣٣۴1٥‏ بواسطة L1 r ER PROFILE‏ ۸ أو عبر ال ٥٥01e‏ لا تؤثر 
على ال «10ووم؟ الحالي للمستخدميين» بل عند دخول المستخدميين في المرة القادمة (ال رمذووم؟ القادم). 
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:DROPPING PROFILE 
عبر استخدام القاعدة التالية:‎ DROP PROFILE باستخدام جملة‎ ٥٣٥۴11٥ یمکن حذف ال‎ 
DROP PROFILE profile name [CASCADE]; 

في القاعدة: 

:CASCD E ۰‏ عند کتابتھا یقوم الأوراکل بحذف e"‏ kمںء‌۸8"‏ ال ۴٥۴11٥‏ من المستخدمیین الذين 

.Default Profile J| خصص لهم وتحويلهم اذى‎ 
:8.3 مثال تطبيقي‎ 
:Pr٥۴[م لحذف‎ 
DROP PROFILE myprofile CASCADE; 

أو باستخدام ال 0[eی"ه°٤:‏ 
ادخل الى ال 01¢eء €٥"‏ عبرع .Standal0o n‏ 
اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر. 
أدخل اسم المستخدم وكلمة السر مع(إالتاكد من اختيار S۷¥5S(584‏ عوضاً عن إوصإه.. 
اضغط على + .Sêcurity Manager J|‏ 
اضغط على + ال ٥1گه‏ ۴ واختر اسم ال اذى المراد حذفه ثم بواسطة الزر اليمين للفارة اختر 
من القائمة “۸٠0۷٥”‏ (يمكن استخدام قائمة†ءع زط0 ثم 8٠٠0۷٠‏ عوضاً عن الزر اليميين 


للفأرة). 
اختر و۷6. 


ملاحظات: 


1- لا يمکن حذف .Default Profile J|‏ 
2- عملية الحذف لا توثر على ال «هاووم؟ الحالية للمستخدميين. 
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RESOURCE MANAGEMENT 


بالتحکم بال و6٥ںمءم8‏ باستخدام ال م1اگه ۴ يمكن تنفيذ عدد من القيود منها تحديد أقصى وقت يمكن 
للمستخدم ان يظل متصلاً بال مءءوطه)ه0 › وأقصى وقت يمكن أن يظل المستخدم في ال مووطه)0a‏ دون 
القيام بمهمات "ء[4[" › وتحديد عدد ال ور مإووم؟ التي يمكن للمستخدم أن يحصل عليها في نفس الوقت. 
يجب تحدıد‏ اlعlمJ Initiliazation Parameter File gû RESOURCE_LIMIT "Parameter"‏ 
بالقيمة ۸1٤‏ لكي نتمكن من التحكم بال وعcاuموم‌R‏ » مع الإعتبار أن القيمة ال )إuوfء5‏ هي 
٤۳ا۴۸‏ يمكن تغيير قيمة العامل بطريقة دايناميكية تظل سارية المفعول الى أن يحدث إغلاق لل 
Database‏ باستخدام ER SYSTEM‏ ۸1۲ کما في المثال 8.4. 


مثال تطبيقي 8.4: 
لتغيير قيمة العامل "٤501 R٣ E٤_ L1۷1‏ بطريقة دايناميكية: 


ALTER SYSTEM SET RESOURCE LIMIT = TRUE; 


للتحكم بال و٥ءإںهءء8‏ يتم تحديد العوال التالية في ال ٥ا۴1‏ ۲۲: 


:)P€U_PER_SESSION °‏ يتم تحگيدركم من الوقت يمكن لل «ه٥اووم؟‏ الإستهلاك من وقت ال 
1 الذي هو المعالج "0۲ء٠٠٠۲"‏ فيٍجهاز الكمبيوتر الذي يتم فيه كل العمليات (يمكن إطلاق 
عليه اسم "عقل الكمبيوتر ")» بحيث يتم تحديآ قيمة العامل بأجزاء من الثانية. 

:)P1_PER_CALL‏ يتم تحديد كم من الوقت/يمگن لجتملة واحدة من جمل 5Q1‏ الإستهلاك من 
وقت ال €۴€ بحیث یتم تحدید قيمة العامل بأجزاء مڻالثانية. 

:SE 5S] NS_PER_USER‏ تحدد كم ورمزووم؟ يكن للمستخدم أن يملك في ذات الوقت. 
تذكر من الفصل الأول أنه يمكن للمستخدم الواحد اين يكو أكثر من «هإوومS‏ واحد في نفس الوقت 
اذا استخدم آكثر من برنامج مثل SQ P1١5‏ و ORACLE FORMS‏ عدا بعض الحالات 
القليلة. 

:)0NNECT_TIME °‏ يحدد المدة بالدقانق التي يمكن للمستخدم أو ال «ه1ووم؟ البقاء متصلاً 
بال موو اوه( بحيث عند انتهاء المدة يتم اخراج المستخدم من ال مءوطه٤ه(‏ وإنهاء عمل ال 
Session‏ و عمل )ط11 R‏ للمھمات التي تعمل أو لم یحدث لھا )1 .٤)٥۳‏ 

:IDLE_TIME °»‏ يحدد المدة بالدقائق التي یمکن E‏ أو ال ر0وومع؟ البقاء متصلاً بال 
t6‏ بدون القيام بمهمات» بحيث عند انتهاء المدة يتم اخراج اسم من .Database Û|‏ 

PR] E_S6۸ ٠‏ : لتحديد المساحة الخاصة المخجورة لکل ره‌ذوومS‏ في ال S6۸‏ (خاص فقط 
.(Shared Server‏ 

:L10 GA 1_READS_PER_SESSION‏ تحدد عدد ال وی810 وھ التي یمکن قرائتھا 
أو استخراج البيانات منها في ال «هذوومS‏ (يمكن أن تمنع استخراج أحجام بيانات كبيرة). 

:L0G1CA1L_READS_PER_ CALL °‏ تحدد عدد ال ]ها8 Data‏ استخراج البیانات منھا 
لكل جملة SQ]‏ واحدة. 

gy CPU_PER_SESSION ja JÛ جع‎ Jلصاح‎ gy :COMPOSITE_LIMIT ° 
PRIVATE_SGA» LOGICAL_READS_PER_CALLs CONNECT_TIME 
.Rءي0u‎ ce لمعرفة القيمة الكاملة لل وم0‎ 
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:CREATING PROFILE TO MANAGE RESOURCES 
یمکن تکوین ٥[ذ۴ه ۴ لإدارة ال وعءإuمءم8 باتباع القاعدة التالية:‎ 


CREATE PROFILE profile_ name LIMIT 
[SESSIONS_PER_ USER nl] 
[CPU_PER_SESSION n1] 
[CONNECT_TIME n1] 

[IDLE_TIME n1] 

[CPU_PER CALL n1] 
[LOGICAL READS _PER_SESSION n1] 
[LOGICAL READS _PER_CALL n1] 
[COMPOSITE_LIMIT n1] 
[PRIVATE_SGA n2] 


في القاعدة: 


ه 1": هي أحدى هذه اقم .UNLIMITED, DEFAULT, NUMBER‏ 
هه 2: هي أحدى هذه الق .UNLIMITED, DEFAULT, NUMBER K|M‏ 


مثال تطبيقي 8.5: 
لتکوین ۴٥۴1٥‏ للتحكم بال Resources‏ : 


CREATE PROFILE myprofile LIMIT 
SESSIONS_PER_USER 3 
CPU_PERSSESSION UNLIMITED 
IDLE TIME 15 
CONNECT_TIME 90; 


:٤٥٥ 1501e باستخدام ال‎ P۴11 لتحویل‎ 


ادخل الى ال Cons01e‏ عښر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم و كلمة السسر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار 84 $۷95 عوضاً عن إوصإه.. 

.Security Manager J| + اضغخط على‎ 

اضغط بواسطة الزر اليمين للفأرة على مجلد ال ٥اا؟هإ۴‏ واختر من القائمة التي تظهر م٤4٠)°.‏ 
في النافذة الجديدة» ادخل اسم ال ما0۴ ۲. 

ادخل البيانات التي تريد في قائمة إوإءرء6. 

.٤)۲٥4 ٤٥ اضغط علی‎ 
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:USING DATABASE RESOURCE MANAGER 


یمکن استخدام اÛ Database Resource Manager‏ لتوفیر تحکم أکبر لل ۷eامS 0٤1e‏ علی ال 
5ه وكيفية تخصيصها. يجب أن يكون للمستخدم ال م عء ]11ر۴1 اللازمة للتحكم بال مووطوat(‏ 
.ADMINISTER_RESOURCE_MANAGER privilege gas Resource Manager‏ 


ıتjع Resource Manager J|‏ atabaseط‏ الى أربعة أجزاء هي: 


:C0NSUMER GROUP °‏ مجموعة من المستخدمیین یتشارکون في ذات قیم ال ces‏ uهیR‏ 
التي يحتاجونها (كأن يخصص ١11٤ه٣۴‏ واحد لكل مجموعة لأن لديهم ذات الإحتياجات من ال 
.(Resources‏ 

.Consumer Group Û JF Resources ÛJI gıjgتl‎ bط¦þخ‎ :PLAN 

.Consumer Groups Jİ Resources JI gıjgî رÛ‎ :ALLOCATION METHOD ° 

:PLAN DIRECTIVES ®‏ یستخدم من قبل ال D8۸‏ لتوزیع ال ۴1.۸8 علی ال 
.Consumer Groups‏ 


ملاحظة: معلومات أكثر حول ال Resource Manager‏ atabaseط‏ وكيفية استخدامه في دراسة الإمتحان 
الرابع من امتحانات ال D8۸‏ 9iء[Orac.‏ 


.Managing Undo Data درس‎ „û Database Resource Manager JÛ Iiãرطت تذکر:‎ 


:QUERYING INFORMATION 
:۲ 0۴11٥ للحصول على معلومات حول ال‎ 
یستخدم ال‎ › ۴٣ ٥؟ا[e للحصول علی معلومات حول قیم عوامل ال‎ :(8B4_PROFILES ° 
أو‎ ۴ھووسw‎ 0U لتحدید نوع العوامل الھرالاستخراجھا (أما‎ Resource_ Type Column 
.(Kerne] lik ınmتîو‎ Resources 
SELECT * FROM DBA_PROFILES 
WHERE PROFILE = ‘myprofile? 
AND RESOURCE_TYPE = ‘KERNEL’; 

لمعرفة كلمة السر للمستخدم (بشكل مشفر) وحالة ال :۸cc0u)‏ 


(8B USERS °‏ : معلومات حول اسم المستخدم وكلمة السر وحالة ال Account)‏ (مغلق۔ یعمل). 


للحصول على معلومات حول Resource Cost J|‏ )من اwتخدlIم :(COMPOSITE_LIMIT‏ 


:RESOURCE_COST *‏ معلومات حول الأربع عوامل التي يحددlk .Composite_Limit‏ 
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MANAGING USERS 


لكي يتمكن ال 584 من منح فرصة الدخول الى ال مودطه)هD‏ للموظفين › يجب منح كل واحد منهم 
Account)‏ یتکون من اسم مستخدم وکلمة سر یعرف هذا ال ٤ہںہc٥۸‏ باسم ۲٥ءآ.‏ یمکن تخصیص لکل 
مستخدم ممیزات و gesم][۴r¡v¡i‏ و ۴¡1eگ Pro‏ › و "a besp ace‏ لتکوین العناصر c٤"‏ زط0" فیهاء 

وe "em porary "ab esp 2e‏ لتخزين البيانات المؤقته التي تنتج عن عمليات المستخدم» كما يمكن تحديد 
مساحة خاصة للمستخدم من كل مء 4مءع1ط ه۲ تعرف باسم sو٤ u0‏ ع٥‏ 14ط ۲4. كل العناصر 
"ectsزط0"‏ التي يملكها المستخدم في ال عوط 4٤ھ(‏ (مثل de×esہ! 1es, ۷1ew,‏ طھ۲) تعرف باسم 
ه"صءطءS‏ ولا يمكن للمستخدم الواحد أن يكون له أكثر من $c.‏ واحدة. 


:CREATING USERS 
لتكوين ١ءء جديد تستخدم القاعدة التالية:‎ 


CREATE USER user_ name 

IDENTIFIED [BY password | EXTERNALLY] 

[DEFAULT TABLESPACE Tablespace_name] 

[TEMPORARY TABLESPACE Tablespace, name] 

[QUOTA {number K|M | UNLIMITED} ON Tabléspace_name, ...] 
[PASSWORD EXPIRE] 

[ACCOUNT {LOCK | UNLOCK}] 

[PROFILE {profile _ name | DEFAULTY] 


في القاعدةء 


ERNALLYآE×X:‏ سوف نتطرق لھا بعد قلیل. 

:DEFAULT TABLESPACE °‏ تحديد ال ءءدمء6[طه٠‏ التي سوف تخزن العناصر التي قد 
يكونها المستخدم مستقبلا. 

TEMPORARY TABLESPACE‏ : تحديد ال espaceاab remporary‏ التي سوف 
يتم تخزين البيانات المؤقتة الناتجة عن مهام المستخدم. 

٠ه‏ 01۸ل: تحديد مساحة محددة من أي ءء4مءء1ط14 تخصص للمستخدم لتخزين عناصر 
"Objects"‏ فیها. 

SWORD EXPIRE °‏ : لإجبار المستخدم على تغيير كلمة السرء التي عرفت بواسطة 58۸ 
عند تكوين ال ٤ں‏ ٥ء۸‏ عند دخول المستخدم الى ال ٤مںuهء»۸‏ مباشرة. 

C001 ۰‏ : لتحدید اذا ما کان یرید ال 8۸( تکوین ال ۸٥٥ u٤‏ جاھز للعمل مباشرة أو أن 
رکون مغن تم رتم فتكه ب فترة. 

PROFILE ®‏ : تحدید ال e[اfما۴‏ المخصص للمستخدم. 
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مثال تطبيقي 8.6: 
لتکوین ۲٥ء‏ جدید : 


CREATE USER Ahmad 
IDENTIFIED BY newemp 
DEFAULT TABLESPACE data 
TEMPORARY TABLESPACE temp 
QUOTA UNLIMITED ON users 
QUOTA 2M ON indx 
QUOTA 10M ON data 
PASSWORD EXPIRE; 


لتکوین یل باستخدام ال 01یہ :٤٥‏ 


ادخل الى ال Cons01¢‏ عڊر .Standalone‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم و كلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷5584۸4‏ عوضاً عن إوصإه.. 
اضغط على + .Security Manager Û|‏ 

اضغط بواسطة الزر اليمين للفأرة على مجلد ال ١ءء‏ واختر من القائمة التي تظهر ٥٤۸٠إ).‏ 
في النافذة الجديدةء ادخل البياناتفيقائمة [4٥"ء6‏ وقائمة .©1U0714‏ 

اضغط علی ٥)4٥إC٤.‏ 


:Operating System Authentication 


يمكن السماح للمستخدميين الدخول الى ال ءءوطه)ه( دون استخدام كلمة سر › هذا يعني بمجرد استطاعة 
المستخدم الدخول الى نظام التشغيل عبر نظام الحماية المعمول فيه في نظام التشغيل (قد يكون كلمة سر خاصة 
بنظام التشغيل patin System"‏ ") يستطيع المستخدم الدخول الى ال #ءووطه)ه 0 دون الحاجة الى 
كلمة سر خاصة بالأوراكل. لتطبيق هذا النظام یجب استخدام كلمة 1¥ E×1٤R۸ N۸‏ في جملة 

CREATE USER‏ بتحديد العامل ×| 08_A۸ UH ENT1_PREF‏ یمکن تمییزاسم المستخدم في نظام 
التشغيل واسم المستخدم في ال مووطو)د › حيث أن القيمة ال ٤ا‏ وء لهذا العامل هي ۲5$ 0. 


متال: 


اذا كان المستخدم مؤهل للدخول عبر حماية نظام التشغيل ( التي تطلب من المستخدم كتابة اسم و كلمة سر) 
الى ال مووطه)ه( وكان اسم المستخدم في نظام حماية نظام التشغيل هو لد ط۸ فإن اسم المستخدم في ال 
.OPSŞ$Ahmad jùyكı Database‏ 

عندما يطلب المستخدم 4 .ط۸ الدخول الى ال مءوطه)ه( › فليس مطلوباً من ادخال كلمة سر أو اسم 
مستخدم اذ يقوم الأوراكل بمعرفة اسم المستخدم في نظام التشغيل (ل و ۸1) وربطه مع ال Acco "٤‏ 
الخاص به .)(OPS$Ah144(‏ 
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ملاحظة: تغيير قيمة ال ×۴1 05S_A U1" ٢E N1_ ۲۸٤‏ فد يؤدي الى منع المستخدميين من الدخول الى ال 
se‏ t4هط‏ (الذين يسمح لهم الدخول الى مووطه)ه بدون كلمة سر). 


يمکن استخدام عامل أخر ھو EMOTE_0S_۸U 711٤ N1‏ "۴ لتشغيل أوغلق امكانية الإتصال بال 
Remote Database‏ عبر نظام التشغیل (لا ينصح باستخدامه لإمكانية حدوث اختراق لل مءوط ه٤0‏ ). 


مثال: 

مثال على استخدام E_O0OS_AUTHÊNTآEMO"‏ » دخول المستخدم (لديه إمكانية الدخول الى ال 
)هط عبر حماية نظام التشغیل) الى نظام تشغیل (مثل ال ×زہا) متصل مع Orac[e Sever‏ 
الموجود على جهاز اخر٬›‏ في حالة وضع قيمة العامل ں٣۰‏ فان المستخدم يستطيع الإتصال بال 


Database‏ أما في حالة القيمة مءاه۴ (هي ال ٤اuںو؟ه0)‏ فإن المستخدم لا يستطيع الإتصال بال 
ata be‏ ویستطیع فقط اذا كان ال إمرإمS‏ م[ءهإ0 موجود على ذات الجهاز الذي دخل إليه. 


ORACLE SERYER INSTALLED HERE 


آےا 


اک 


OS AUTHEN 
CONNECTION 


USER 


NO ORACLE SERVER INSTALLED 
841 رسم‎ 


:ALTERING USERS 

Temporary JI Î Default Tab1espace J| لكي يتم تير‎ ۸11۲٤۸ 1S۴ يمکن استخدام جملة‎ 
.Quota Û yi Tablespace 

مثال تطبيقي 8.7: 

لتغییر ال ٤٥ں‏ للمستخدم: 


ALTER USER Ahmad 
QUOTA 0 ON users; 


ملاحظة: في حالة تغيير قيمة ال ٤0ں‏ الى صفر وكان للمستخدم 141٥‏ في «Users Tab] espace Û|‏ 
فان هذه ال ۲۵1۲ لا یمکن أن یکبر حجمها أبداً (لا تستطیع حجز مزید من ال .)٤×) ٤s‏ 
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أو عبر ال 501e‏ «هC€:‏ 


ادخل الى ال 01eی‏ "°0 عبر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إوصرإ٥..‏ 
اضغخط على + .Security Manager J|‏ 

اضغط على + بجانب المجلد ءامو ا› ثم اختر اسم المستخدم. 

غير البيانات في النافذة اليمنى. 

اضغط على رامم۸. 


:DROPPING USERS 
يمكن حذف مستخدم من ال م44 طه)هD باستخدام القاعدة:‎ 

DROP USER user name [CASCADE] 
في القاعدة:‎ 


:AS CADE‏ باضافتها الى الجملة(يتم حذف كل العناصر "ءءء زط0" التي كونها المستخدم في 
ال ٥a‏ طء؟ الخاصه به. 


ملاحظة: لا یمکن حذف مستخدم متصل بال 46ط 4ھ ¢5 یمکن استعمال × SESS10‏ 1ا1 لإخراج 
المستخدم ثم حذفه من ال #ءوطه)04. 


مثال تطبيقي 8.8: 


لحذف مستخدم: 
DROP USER Ahmad;‏ 


:QUERYING INFORMATION 


:D(BA_ USERS *‏ یمکن الحصول علی معلومات حول اسماء المستخدمیین و ال t٤اuو؟e‏ 5( 
remporary Tablespace ÛJI Tablespace‏ و اسم ال 1eگPr0‏ وتوقیت تکوین ال ۴0۴11 
وحالة ال ٤ں‏ ٠0ء٠۸‏ لجميع المستخدميين وغيرها من المعلومات. 


:D(8BA_1S_QU0 AS‏ توفر معلومات حول ال وو٤‏ 0ں المخصصة للمستخدميين من ال 
.Tablespaces‏ 
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اذہل الت اسح 


إدارة البريفليج و أودبوتين 
وول 


Managing PRIVILEGES & 
AUDITING & ROLES 
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PRIVILEGES 


باستخدام ال ومعم[ذ۷آ۴ يمكن وضع حدود لكل مستخدم في ال مودطه)۰04 مثال على ذلك حدود على 
المهام التي يستطيع تنفيذهاء وحدود على البيانات التي يستطيع تعديلها. يمكن إعطاء ومعم |۷¡" 
للمستخدميین بشكل مباشر أو أن يتم عبر ال و16ه8 › كما يمكن إعطاء ومعم][زرآإ" عامة لجميع 
المستخدميين وذلك عبر إعطاء ال ومعم ]ذر۴ الى مجموعة تعرف باسم عiااuں۴‏ وهي مجموعة ينتمي إليها 
جميع المستخدميين في ال #ووطه)ة0. 


یوجد نوعیین من ال اار1" هما: 


.'"0bطزec)ء'" وضع حدود وقیود علی العناصر‎ :0 BJ EC٣ Privileges 
وضع حدود على المهام التي يستطيع المستخدم تنفيذها في ال‎ SYS EM Privileges 
بشکل عام.‎ Data 


:SYSTEM PRIVILEGES 


یوجد عدد کبیر من ال می۴۷11 صع)ول؟ في ال مءوطه)ه يتم تخصيصها للمستخدمين باستخدام جملة 
GBR ANT‏ ویتم إعادتھا (إلغائھا) من االمستختڌمین باستخدام جملة .N۸ £۷ O) ٤‏ یمکن توزیع اÛû System‏ 
Prive‏ الى ثلاثة أقسام » قسم متعلى/بالأمءدط هاه( بشكل عام » والقسم الثاني متعلق بال وء طءS؟S‏ 
الخاصة بالمستخدم › أما القسم الثالث فمتعلقآجال وو ٠1ء5‏ الخاصة بالمستخدميين الأخرين. نسق ال 

عع ]ااا في النوع الثالث والرابع متشابه#من#حيث الجملة ولكن يضاف كلمة ۸١۲‏ للنوع الثالثء مثال 
على ذلك CREATE TABLE‏ (النوع الثاني( و CREATE ANY TABÊE‏ (النوع الثالث). 


:System Privileges J| ja 


ALTER SYSTEM 

ALTER SESSION 

ALTER DATABASE 
CREATE TABLESPACE 
CREATE TABLE 

CREATE PROCEDURE 
CREATE CLUSTER 
CREATE SESSION 
RESTRICTED SESSION 
CREATE ANY TABLE 
ALTER ANY TABLE 
DROP ANY TABLE 
SELECT ANY TABLE 
CREATE ANY INDEX 
ALTER ANY INDEX 
DROP ANY INDEX 
CREATE ANY SEQUENCE 
ALTER TABLESPACE 
DROP TABLESPACE 
UNLIMITED TABLESPACE 
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SELECT ANY TABLE 
UPDATE ANY TABLE 
DELETE ANY TABLE 
BACKUP ANY TABLE 
INSERT ANY TABLE 
GRANT ANY PRIVILEGE 
GRANT ANY ROLE 
SYSOPER 

SYSDBA 


ملاحظات: 


Lai « ANALYZE INDEX privilege si CREATE INDEX privilege دجgı‎ ¥ -1 
CREATE TABLE ءlطعإ بحيث |ذ| ت‎ « CREATE TABLE privilege ga jıılaشم‎ 
ل,].‎ ٥× للمستخدم یستطیع تکوین‎ 


.CREATE TABLE privilege J| jaض†‎ ùa DROP TABLE Privilege -2 
.CREATE PROCEDURE Privilege J| jaض‎ ùa DROP PROCEDURE privilege -3 
.CREATE CLUSTER privilege JI jaa, ja? DROP CLUSTER privilege -4 


UNLIMITED TABLESPACE privilege -5‏ توفر إمكانية استخدام أي مساحة في أي 
"besp‏ › ولکن تخصص فقط للمستخدمیین ولاپیمکن تخصیصها لل 16اه ۸. 


6- لكي يستطيع المستخدم عمل م)ے ,ںآ لاي ٥1ط‏ ھ۲ قي أي و٥طءS‏ یجب أن یخصص له 5۸0۶۲ 
.ANY TABLE‏ 


:Protecting the Dictionary 


عندما يتم منح الnتخدjııa «SELECT ANY TABLE yi ALTER ANY TABLE‏ ڍصبح 

بإامكان المستخدمیین الدخول أو استخدام ال )زط0 راهہهذاء1 › وهذا قد يشكل خطر على ال 
.Databaْe‏ يوفر الأوراكل الoعامل DIC] 0NARY_ACCESSIB1L[ TY‏ _07 من عوامل 
]nitialiation Parameter File‏ الذي يمكن ال D8۸‏ في التحكم في «Dictionary Objects J|‏ 
بحيث عند وضع قيمة العامل مء1ه۴ › يتم منع المستخدميين من الدخول الى جميع العناصر ضمن ال S۷8‏ 
Schema‏ الذي ملك ال .Dictio nary‏ 


148 


:Granting System Privilege 
يمكن إعطاء ومعم ]1آ للمستخدم باستخدام القاعدة التالية:‎ 
GRANT system_ privilege , system_ privilege, ... 
TO {user_name | role name | PUBLIC} , { user_name | role_ name | PUBLIC} ,.. 
[WITH ADMIN OPTION] 


في القاعدةء 


.R‌هامو کما ذکرنا سابقاً آنه یمکن منح ال وععم ا۴۷1 لل‎ :Role_ name 
يستطيع المستخدم الذي تلقی ال ٥ع ][1ہ!ا٣ إعطاءها‎ :W ۲H DMIN OPTION ° 


مثال: 
لفهم :WITH ADMIN OPTION‏ 


يوجد ثلاث مستخدمیین الأول هو ال 8۸( والثاني هو 44 ط۸ والثالٹث ھو ےہ 0. قام ال 8۸( بإعطاء 
Ah na d/مدختسملل CREATE ANY TABLE‏ مع استخدام ›W1TH ADMIN OPTION‏ في 
هذه الحالة يمكن للمستخدم | CREATE ANY TABLÉ ¢+ HÊA hı ı2‏ للمستخدم اھ 0. آما في حال 
عدم ذکر جملة ×110 WI] ADMIN 0٢0P‏ › فلا یمکن للمستخدم Privilege J| sibe) Aha ıd‏ 

للمستخدم 0,2۲ › ویجب على ۲و0 الحضول على ال ءعء11رآإ۴ من (المستخدم الذي لدية إمكانية منح 
.DBA ÛJ! ( Privileges Û|‏ 


:9.1 مثال تطبيقي‎ 
GRANT CREATE"ANY TABLE TO Ahmad, Omar; 


GRANT ALTER ANY TABLE, ALTER ANY INDEX 
TO Ali WITH ADMIN OPTION; 


أو عبر ال 0[eی«هC€:‏ 


ادخل الى ال Cons01¢‏ عڊر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إوصرإه.. 
اضغخط على + .Security Manager J|‏ 

اضغط على + بجانب المجلد ءامو ا› ثم اختر اسم المستخدم. 

.System Privileges nilقll اختر‎ 

اختر ال ٥ء۴1۷1‏ من القائمة العليا ثم اضغط على المثلث المتجه الى أسفل. 

ضع علامة صح في قسم دنام 0 «ذص ۸4 اذا كنت تريد ذلك. 

اضغط علی رارم ۸. 
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:Revoking System Privilege 


يمكن سحب أو |lزlء Privileges Û‏ الممنوحة للمستخدم باستخدام القاعدة التالية: 


REVOKE system _ privilege , system_privilege, ... 
FROM {user _ name | role_ name | PUBLIC} , { user _ name | role name | 
PUBLIC} ,.. 


ملاحظة: في بعض الحلات عند سحب معم ]آ۴ من المستخدم يحدث خلل في باقي عناصر المستخدم. مثال 
على ذلك الخلل الذي قد يحدثه إلغاء CREATE "ABLE‏ من المستخدم الذي قام بتکوین ۶٥[طھ۲‏ 
وس۰۷1 في هذہ الحالة یحدث خلل لل ws‏ ع۷1 لأن ال وس٥۷1‏ معتمدة على ال و6[ط۾1. 


مثال: 
عiد Privilege J REVOKE Jaz‏ وتم استخڏدIم .GRANT ÛJ ge WITH ADMIN OPTION‏ 


WITH ADMIN مIڌختwا‎ ga Ahmad للمستخدم‎ CREATE ANY TABLE ءlطþelڊ‎ DBA J| قم‎ 
.Omaإ للمستخدم‎ CREATE ANY TABLE بإڑطاءٍ‎ ۸h „2 وقام المستخدم ل‎ 0P] N 

« Ahmad Û ةحوiaall‎ CREATE ANY TABLE Jİ D8#dIjڻبaړ‎ ja REVOKE عند حدوث مر‎ 

Omar ûİ يÎ‎ «Omar من عند المستخدم‎ CREATE ANY DABLE Ji REVOKE ةılnعe لا يحدث‎ 
“CREATE ANY TABLE ÛJI مازال يمك‎ 


مثال تطبيقي 9.2: 


REVOKE CREATE ANY TABLE FROM Ahmad, Omar; 


أو عبر ال 0[eی«هC٤:‏ 


ادخل الى ال 01eی °٥0"‏ عبر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إوصإه.. 
اضغخط على + .Security Manager Û‏ 

اضغط على + بجانب المجلد ءم ول٠‏ ثم اختر اسم المستخدم. 

.System Privileges ةnأlقلl اختر‎ 

اختر ال ٥عء‏ ۴۷1 من القائمة السفلى ثم اضغط على المثلث المتجه الى أعلى. 

اضغط على رام‌م۸. 
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:OBJECT PRIVILEGES 


Table, View, Sequence, J| Jذlع توفر ال geءP¡v¡1 زط0 إمكانية القيام بمهمات محددة‎ 
.Procedure, Function, Package 


:Object Privilege JI من‎ 

.Table, View, Sequence J| ja بیانات‎ ) ue تمکن المستخدم من استخراج أو قراءة (ر‎ :SELE٣T 
.٣ھ1e,‎ ۷1W تمکن المستخدم من تعدیل البیانات في ال‎ : 1P 1٤ 

.٣ھطاe,‎ ۷1W تمکن المستخدم من حذف البیانات في ال‎ :P E LEE 

.٣۵(1م,‎ ۷1W تمکن المستخدم من إضافة بیانات الی ال‎ :!N SERT 

.Table, Sequence, Procedure J| jيyكت‎ Jيدعت ا : تمكن المستخدم من‎ ER 

.۲ھط1e,‎ ۷1W ہ!] في ال‎ ٥× تمکن المستخدم من تکوین‎ :1ND( ٤× 

. تمکن المستخدم من‌رتکوین ره ع٤٣٥۴ في ال 1۲ھ‎ : REFERENCES 


.Procedure, Function J| Jûم‎ °P[/$Q1 تمکن المستخدم من تشغیل برامچ ال‎ :EXECاU‎ TE 


:Granting Object Privilege 
يمکن إعطاء وععم ]1ر۴ للمستخدم باستخدام القاعدة التاليةء‎ 
GRANT object_privilege, objeê€®privilege, ... | ALL [PRIVILEGES] 
ON [schema.] object_ name 
TO {user_name | role name | PUBLIC} ,.... 
[WITH GRANT OPTION] 
في القاعدةء‎ 
Object Privileges JI J slbe¥ :ALL 
يستطيع المستخدم الذي تلقی ال sععم ]۲1۷1 إعطاءها‎ :W1 ۲H GRANT OPTION 
لمستخدميين أخريين.‎ 
ملاحظات:‎ 


1 لکي يستطيع مستخدم إعطاء ومع ]ذ۴1 ٤زط0‏ الى مستخدم أخر» يجب أن يكون ال ٤ءءزط0‏ في ال 
Schema‏ الخاصة به و تم إ|eطosl Object Privilege‏ مع استخدIم .WITH GRANT OPTION‏ 


2- لكل مستخدم وععء‌آ¡۴¡۷ ٤ءء‏ زط0 كاملة على ال ءءء زط0 الموجودة في ال و١ءطء$‏ الخاصة به. 
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مثال تطبيقي 9.3: 


GRANT UPDATE ON hr.employees 
TO Ahmad 
WITH GRANT OPTION 


أو عبر ال 0[eو«هC€:‏ 


ادخل الى ال 01e‏ °0 عبر .Standalone‏ 

اضغط على اسم ال مءطهه( لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷5S584‏ عوضاً عن إوصإ٥..‏ 
اضغخط على + .Security Manager J|‏ 

اضغط على + بجانب المجلد ءمء لا ثم اختر اسم المستخدم الذي ترید أن تعطیه ال eعء‏ ا1 مثل 
.PM‏ 

.Object Privileges ةnأlقll اختر‎ 

اختر من القائمة العليا اليسرى اسم المستخدم (مثل 1) الذي يملك ال ٤ءءزط0‏ المراد أعطاء 
Privilege‏ لل .PM‏ ثم اختر نوعیة ال e٥٤‏ زط0 (مثل ٥1ط )٣٣‏ ثم اسم ال ٤زط0‏ (مثل 
(Employees‏ 

اختر نوعية ال eعم[۷1إ۴‏ من_القائمة اليمنى (مثل مول م ا). 

اضغط على السهم المتجه الىلأسفل. 

اضغط علی رام‌م۸. 


:Revoking Object Privilege 


يمكکن سحب أو |lزs‏ || Privileges‏ الممنوحة للمستخدم باستخد(ك القاعدة التالية: 


REVOKE object_privilege, object privilege, ... | ALL [PRIVILEGES] 
ON [schema.] object _ name 

FROM {user _name | role name | PUBLIC} ,.... 

[CASCADE CONSTRAINTS] 


ملاحظة: لكي تتم عملية ال مم8 › يجب أن يقوم بالعملية ذات المستخدم الذي قام بعملية ۲وإ6. 


في القاعدة: 


:CASCDE CONSTRAINTS‏ لحذف ال es‏ ع٥۲٥۴‏ التي تکونت باستخدام 
.REFERENCES privilege‏ 
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مثال: 


.GRANT JI ga WITH GRANT OPTION pIڌختwl‎ pûg Privilege Û REVOKE Jaz ie 


WITH GRANT مlدخت~ا‎ ga Ahmad pدختwnll‎ SELECT TABLE ءlطelڊ‎ Ali قام المستخدم‎ 
.O na! للمستخدم‎ SELECT TABLE بإعطاءٍ‎ ۸h 2| وقام المستخدم‎ »0P1]0N 

عند حدوث أمر RE۷ O) ۴٤‏ من قبل ال SELECT TABLE Ûل A۸11‏ الممنوحة ل ۸14 › یحدث 
عمل SELECT TABLE Ji REVOKE‏ من عند المستخدم ھم 0» أي أن 0"۲ یفقد 
SELECT TABLE‏ ايضا. 


مثال تطبيقي 9.4 


REVOKE SELECT ON hr.employees 
FROM Ahmad, Omar; 


أو عبر ال 0[eی«ه٤:‏ 


ادخل الى ال 501e‏ "°0 عبر .Staîdalone‏ 

اضغط على اسم ال مءهطه)ه( لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاك"من اختيار 84 S۷55‏ عوضاً عن إوصإه.. 

.Security Manager J| + اضغط على‎ 

اضغط على + بجانب المجلد ءءء » ثم اختر اسم الكستخدام الذي ترید استرجاع ال ومعم |۴۷" 
منه. 

.Object Privileges ةnilقll اتر‎ 

اختر ال ٥ع‏ ء۴۷1 من القائمة السفلى ثم اضغط على المثلث المتجه الى أعلى. 

اضغط علی رام‌م۸. 


:QUERYING INFORMATION 


للحصول على معلومات حول :System Privileges JI‏ 


:DBA_SYS_PRIVS‏ توفر معلومات حول ال esعماز۷¡اP System‏ الممنوحة ای ,ومول 
.Roles‏ 


:D(B A_1 AB_PRIS‏ توفر معلومات حول ال sءعماا۷آإ۴‏ ٤ءء‏ زط0 الممنوحة والمستخدم 
الذي منح ال ومعماذہ۴1 وغيرها. 


:SESS10N_PRIVS‏ توفر معلومات حول ال وععء‌آز۷آا۴ ۳ءtءر؟‏ الممنوحة للمستخدم 
الحالى (ىمiذوومS).‏ 
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AUDITING THE DATABASE 


عملية ال عمنازق ں۸ هي عملية مراقبة مهمات ال مووطههD‏ المختلفة بحيث يتم مراقبة أي عمليات مشتبه 
في أنها غير مسموح فيها كأن يقوم مستخدم غير مسموح له بالدخول الى ال مءوطه)ه( بالدخول وحذف 
بيانات من ال مءوطها4(. يتم جمع بيانات ومعلومات حول المراقبة في ۸100$ التابعة ل وءطءء $۷8 » 
أو يمكن جمع هذه المعلومات في ملف خارجي في نظام التشغيل "١.ءاءر؟‏ ع«ناهإءم0". لتسجيل 
المعلومات الناتجة عن عملية ال مزق ں۸ › يجب وضع قيمة العامل ۸11 ۲R‏ 9۲ا۸ بالقيمة True‏ 
أو 8( ٠‏ أو يمكن استخدام ملف خارجي بوضع قيمة العامل 0S‏ أما القيمة ال ٤ا‏ وء للعامل هي 

.N ONE‏ يقوم الأوراكل بعمل عد) 1ك ں۸ في بعض الحالات وإن كانت قيمة العامل ٠٠‏ مثل عند تشغيل 
و إغلاق ال مء۸ وو[ أو لمراقبة ال ومعم اذإ الخاصة لل 84( (أو كل مستخدم يملك ومgم]¡ivاP‏ 
مشابه لل 08۸). 

لل D84‏ حرية تحدید اذا ما كان يريد ان تحدث عملية ال ع«ازقں۸ عند المهمة المراد مراقبتها ( ر8 
ssءعءA)‏ أو لكل ال «مذوومS‏ بغض النظر عن عدد المهمات التي تحدث(,10وءه؟S .)8y‏ 


باستخدام عملية ال )زل ں۸ يمكن مراقبة: 
جمل ال SQ‏ 


.Privileges J| e 
."0(ز٥ء)ء'" العناصر‎ ه٠‎ 


ملاحظة: یطلق علی ۸17$ اسم 11و۲۲ ال1 #۸وهي من نوع ال و»اطه1 م8 وهي الوحيدة التي يمكن 
لل 8۸( تعدیلھا كما جاء ذكرها سابقاً. 
اذا امتلئٰ ملف ال 1ذإ٣‏ ٤1ل‏ ں۸ بحيث لا يمكن إضافة معلوكاتالمرةاقبة الى الملف › تتأثر جميع جمل ال 
1 المراقبة وعوضا أن تظهر النتائج الطلوبة › تظهر أخطاء هوم ."E ۲۲٠۲‏ ولذلك يجب تفرغة 
ملف ال ]ز۲۲۵ ں۸ بشکل مستمر. للتحکم في حجم ال 1ذ۲۲۵ 6زا ں۸ › ینصح باستخدم ال عہAudi)1‏ 
عند الضرورة فقط › واختيار نوع المراقبة بدقة (ال $1 أو العناضر أو ال وج۷11٣‏ ۴) » وعدم إعطاء ال 
D1۲ ANY privileges‏ ۸ لمستخدمیین کثیرین واستخدام ر0ذوو6؟ ر8 عوضاً عن وم۸۲ .8y‏ 
ملاحظة: لحذف محتویات ال 1ذ ھ٣٣‏ ٤ں A‏ « تستخدم جمJ .TRUNCATE JI Î DELETE J|‏ 
يمكن حماية ملف ال 1ذه۲۲ ٤ل‏ ں۸ بكتابة التالي: 

AUDIT DELETE ON SYS.AUDS BY ACCESS; 
أخرى»ء مع مراعاة اعادة‎ "a ط1espace الى‎ SYSTEM TABLESPACE Ûا يفضل نفل ال 5ا۸ من‎ 


تعریف ال وe×e‏ لہ[ علی کل من ال وروص uں1هC‏ التlئية .(sessionid , ses$tid)‏ 


تذکر: یجب اعادة تعریف ال ومe×مل.]‏ عند نقل ال و16 .٣۵(‏ 
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مثال تطبيقي 9.5: 
مثال على القيام بعملية عمزا ز۸ لجمل ال 8@1: 
لمراقبة جمل ال DD.‏ التي تنفذ على ال وم[طه : 
AUDIT TABLE;‏ 
مثال على القیام بعمٺية :Privileges JÛ Auditing‏ 
AUDIT CREATE ANY SEQUENCE;‏ 
مثال على القيام بعملية عم1† ں۸ لل :0bjects‏ 


AUDIT UPDATE, DELETE ON HR.EMPLOYEES; 


:AUDITING OPTIONS 
يمكن استخدامها لتحديد عملية المراقبة بشكلأكبر.‎ 
يتم جمع معلومات حول‎ › 5Q1 فلي حالة مراقبة جمل ال‎ ¥ HENEVER SUCCESSFUL ° 
الجمل التي تمت بنجاح ولا يتم تسجيل معلومات حول الجمل التي لم تنجح في القيام بمهمتها.‎ 
یتم جمع‎ › 8Q في حالة مراقبة جمل ال‎ :W HENEVER NOT SUCCESSFUL 
معلومات حول الجمل التي لم تنجح ولا يتم تسجيل إمعلوماثبحول الجمل التي نجحت في القيام‎ 
بمهمتها‎ 


.BY ACCESS ° 
.BY SESSION ° 


مثال تطبيقي 9.6: 
لمراقبة عمليات تكوين ور هاووم؟ (دخول المستخدميين لل مsوطها04)‏ : 
AUDIT SESSION;‏ 
العمليات الناجحة فقط: 
AUDIT SESSION WHENEVER SUCCESSFUL;‏ 
العمليات التي لم تنجح: 


AUDIT SESSION WHENEVER NOT SUCCESSFUL; 
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:NOAUDITING 

لايقاف عملية ال عمنزu‏ ۸ » تستخدم جملة 11 N0۸10‏ مع اضافة الجزء الذي تم مراقبته في عملية 
.Auditing‏ 

مثال تطبيقي 97 

للقيام بعملية :Noauditing‏ 


NOAUDIT UPDATE, DELETE ON HR.EMPLOYEES; 


:QUERYING INFORMATION 

للحصول على معلومات حول ال ڇہ!)Audi:‏ 
DEF_ AUDIT OPTS‏ 4ا توفر معلومات حول .Deafult Audit Options J|‏ 
:(8۸_S1M_AUDIT_OPTS °‏ توفر معلومات حول عمليات المراقبة على جمل ال اSQ؟.‏ 


:D(BA_ PRIY_AUDIT_OPTS *‏ توفرتغلومات حول عملیات المراقبة على eعم]¡۲]v.‏ 


:D(BA_ OBJ_AUDIT_ OPTS °‏ توفر معلوماتر حول عملیات المراقبة على واءe‌زط0.‏ 


للحصول على المعلومات الناتجة من عملية ال عمز)ز۸ud:‏ 
:D8BA_AU DIT TRAIL‏ جميع المعلومات الناتجة من عملية ال عمذ) .A di‏ 
DB A_AUDIT_ OBJECT °‏ : المعلومات الناتجة من عملية ال gمuditi A‏ علذى .Privileges‏ 


DB A_ AUDIT STATMENT °‏ : المعلومات الناتجة من عملية ال عہن)زقں ۸ على جمل ال 
.SQL‏ 


:D8۸_A U DI_SESSION‏ المعلومات الناتجة من عملية ال ع«)زdں۸‏ على دخول و خروج 
المستخدميين من ال مsوطو)0a.‏ 
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MANAGING ROLES 


تسهل ال و8016 عملية إدارة ال ومعع][ذہ۴1 لأن ال مإهR‏ عبارة عن مجموعة من ال وعم ]1ہ]إ٥‏ تعطى 
أو تلغى من المستخدمين دفعة واحدة. مثال على ذلك اذا راد ال 58۸ إعطاء عشرة ومعم[زہ٣‏ لكل 
مستخدم جديد في ال مءوط هه › فيجب على ال 84( كتابة جملة R۸۸1‏ عشر مرات › وكذلك الحال 
مع جملة "EVOKE‏ › اما عند استخدام ال R1٥‏ ۰ یتم کتابة جملة G۸ ANT‏ أو REVOKE‏ مرة واحدة 
فقط. یمکن أن یتکون ال 1۲ه‌۸ من ال gesع]P¡vi System‏ وال Object Privileges‏ معا › ولا ینتمی ال 
ماRo‏ الى أي 4" عطءS‏ › ویتم تخزین بیانات حول تکوینه في ال راھ" ٥ناء¡9(‏ 04)4. 


:CREATING ROLES 
يمكن تكوين و1٠8 باستخدام القاعدة التالية:‎ 


CREATE ROLE role_ name [NOT IDENTIFIED 
| IDENTIFIED { BY password | EXTERNALLY } 


في القاعدةء 


.R0 [1e يۇجداڭماية على ال‎ ¥ :NOT DEN TIFIED 
مثل استخدام كلمة السر أو غيرها.‎ 8٠16 يوجد حماية علئ,ال‎ :[( ENT 1F]ED 
مثل حماية نظام التشغيل.‎ 8٠1٠ يستخدم حمايتة كاراجية لل‎ :EX×"ERNALLY 


ملاحظة: يوجد أنواع حماية أخرى لل م۸01 عدا كلمة الس أىرااو1إء)×5 لا مجال للتطرق لها في الكتاب. 


مثال تطبيقي 9.8: 
لتکوین R01٥‏ : 


CREATE ROLE newusers; 
او:‎ 
CREATE ROLE newusers2 IDENTIFIED BY n6iut300; 


أو عبر ال 0[eی«ه٤:‏ 


ادخل الى ال Console‏ عڊر .Standalone‏ 

اضغط على اسم ال مووطه)ه لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S584؟¥S‏ عوضاً عن إومإه.. 
اضغط على + .Security Manager J|‏ 

اضغط على بالزر اليمين للفأرة على المجلد وم1إمR‏ › ثم اختر من القائمة مtو٠إC.‏ 

ادخل اسم ونظام حماية ال م801 ثم اضغط على ٥٤وءإC٤.‏ 
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ملاحظات: 


1- بعد تكوين ال R1‏ مباشرة › تكون ال 8٥16‏ خالية تماماً من أي ءءء 11ا۴ ويمكن استخدام جملة 
GRANT‏ لإعطاء ال Roe‏ مجموعة من ال یgeعم]زہ|۲.‏ 


.CREATE ROLE privilege مpدخan‎ sı يجب أن‎ « R01 لتكوين‎ -2 


:PREDEFINED ROLES 
عند تكوين ال مووطه)ه 0 » يتم تكوين مجموعة من ال و16٠8 بشكل أتوماتيكي منها:‎ 
(4)4 تتضمن امكانية الإتصال بال موو‎ R01٥ ضمن هذا ال‎ P¡viاeges‎ Ûا‎ :C0NNECT 
Tables, Views, Synonym, Cluster, ja J ùيوکت وتکوین "هiووم$ › امكانيه‎ 


.Database Link 


RESOURCE‏ : ال egesاvi Pri‏ ضمن هذا ال 81۲ تتضمن امکانية تکوین کل من اھ 
.Cluster, Sequence, Functions, Procedures, Triggers‏ 


:SELEEE CATALOG_ROLE °‏ ال Prive ges‏ ضمن هذا ال 8016 تتضمن امكانية 
استخراج بیانات ال ر اھ٣ Data 9)٤٥‏ (عمل Query‏ علی ال 16sطھ٣‏ وال .)۷ieWws‏ 


:DELETE_CATALOG_ROLE °‏ إل egeاvi Pi‏ ضمن هذا ال م81 تتضمن امكانية حذف 
بياناٽ )اتخدIم .Data Dictionary Û ùa (DELETE‏ 


:EXECUTE_CATALOG_ROLE *‏ ال P1636‏ ضمن هذا ال 8٥1۲‏ تتضمن امكانية 
استخدIم‏ جأ EXECUTE‏ ي .Data Dfttionary JI‏ 


:EXP_ FULL DATABASE‏ ال Privilege‏ ضفل هذا ال 8٠16‏ تتضمن امكانية عمل عملية 
.Database Jİ Export‏ 


:EXP_ FULL _ DATABASE‏ ال egeاPvi‏ ضمن هذا ال 8٥16‏ تتضمن امكانية عمل عملية 
.Database Jİ Import‏ 


ملاحظة: سوف يتم التطرق على عملیات ال 0۲ م×۴E‏ و ال ٤امم_]‏ في دراسة الإمتحان الثالث من امتحانات 
.Oracle9i Û‏ 


تذكر: من أنواع ال sسwعذ۷‏ رإه« هنا¡( و٤0‏ نوع D8۸_‏ الذي يمكن أن للمستخدم الدخول الى بياناته 
اذا کان يمأ .SELECT_CATALOG_ROLE ÛJI‏ 
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:MODIFYING ROLES 


يمكن تغيير نظام حماية ال م801 أو حذف نظام الحماية باستخدام جملة ۸L ER ROLE‏ کما في 
المثال 9.9. 


ملاحظة: لتعديل نظام حماية ال R01‏ › يجب أن يكو أnستخدم .ALTER ANY ROLE privilege‏ 


لتعديل نظام حماية ال م[هR:‏ 

ALTER ROLE newusers2 IDENTIFIED EXTERNALLY; 
أو احذف نظام الحماية:‎ 

ALTER ROLE newusers NOTIDENTIFIED; 

أو عبر ال 0[eئره٤:‏ 
ادخل الى ال 01eیہ C0‏ عیبر .Staîdaloٍîîe‏ 
اضغط على اسم Database Û‏ لکن تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 
أدخل اسم المستخدم وكلمة السر مع التاكدرملن اختيار S(584؟S۷‏ عوضاً عن إوصإه.. 
اضغط على + .Security Manager Û|‏ 
اضغط على + بجانب المجلد وم1هR‏ › ثم اختر اسم ال R٠1٥‏ المراد تعديله. 


في النافذة اليمنى › اختر نظام الحماية من قائمة 6نا .Auth e”14‏ 
اضغط على رام م ۸. 


:ASSIGNING PRIVILEGES TO ROLES 
خالية تماماً من أي ی٥ ع ]۴۷1 ويمكن استخدام جملة‎ 801٥ مباشرة › تكون ال‎ 801٥ بعد تكوين ال‎ 
10 الى المستخدمیین مع ذکر اسم ال 801 بجانب كلمة‎ P1] التي استخدمت لإعطاء وع عم‎ GBR A N1 
.9.10 عوضاً عن اسم المستخدم أو ال عاط ں۴ كما في المثال‎ 
:9.10 مثال تطبيقي‎ 
:Roles ÛJI Jll Privileges slطey!‎ 
GRANT CREATE ROLE TO adminusers; 


GRANT SELECT ON HR.EMPLOYEES TO newusers2; 
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أو عبر ال 0[eی«هC€:‏ 


ادخل الى ال Con s01e‏ عبر .Standalone‏ 

اضغط على اسم ال مء4طه)ه( لكي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إورإه.. 

.Security Manager J| + اضغخط على‎ 

اضغط على + بجانب المجلد وم[مR‏ › ثم اختر اسم ال 801 المراد إضافة ومعم‌]ا۴]۷1 له. 

أختر إما قائمة وsمgم]v¡1¡اP System‏ أو قائمة sەgعاPivİ‏ tءءزط0‏ » ثم اتبع ذات الخطوات التي 
تم فيها أعطاء المستخدمیین ال ومع م]¡۴|۷. 

۰ اضغط على رام‌م۸. 


:ASSIGNING ROLES TO USERS 
التي استخدمت لإعطاء ومعم ]۲ الى‎ K۸ ۸1 يمكن إعطاء المستخدميين ال و8016 بواسطة جملة‎ 
عوضاً عن اسم ال ٥ع [ذں إ۴ كما في المثال‎ 6۸A N1 بجانب کلمة‎ R01 المستخدمیین مع ذکر اسم ال‎ 
.9.11 
:9.11 مثال تطبيقي‎ 
:Roles ÛJI Jll Privileges slطey‎ 
GRANT adminusers T@O"Omar WITH ADMIN OPTION; 
GRANT 'newusers TO Khaled; 
ببعضها.‎ 8٥1٥ کما یمکن دمج‎ 


GRANT newusers TO newusers2; 


ملاحظات: 


1- المستخدم الذي يقوم بتكوين ال 1ه 8R‏ لديه الحق في WH ADMIN OPTION‏ على ذلك ال 
.Role‏ 


2- المستخدم الذي يملڭ GRANT ANY ROLE pri vi1ege‏ یستطیع إعطاء أو إلغاء ال وا۸0 من 
المستخدميين. 


3- يمكن تحديد عدد ال وم1هR‏ التي يمكن أن تكون في الحالة ٠1ع‏ باستخدام عامل من عوامل ال 


Intialazation Parameter File‏ هر„ ٧۸× ENABLED _ ROLES‏ الذي قیمته ال )[اهfء5‏ هي 
20. 
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:ASSIGNING DEFAULT ROLES 
ولكن ليس بالضرورة أن تكون كلها في حالة إ(هم۴›‎ › ۸٠1٠ يمكن للمستخدم الواحد أن يملك أكثر من‎ 
۴ "4b[۲ )اں هم0 والذي یتم وضعه في حالۂ‎ R01 ولکن یمکن جمع مجموعة من ال و16ه8R لتمثل ال‎ 
تستخدم القاعدة:‎ › 0ءوfں[٤‎ R٠1٥ بشكل أوتوماتيكي عند دخول المستخدم الى ال مووطه)ه0. لتعيين ال‎ 
ALTER USER user _ name DEFAULT ROLE 
{ role_name , role_name | ALL [EXCEPT role_name , [role name] ] | NONE } 
في القاعدة:‎ 
.£E×X€) ٤۲1 1ا : یمکن تعیین کل ال و16٥8 عدا المشمولییین في جملة‎ ]EX٣CEPT...] 


ملاحظة: يمكن استخدام هذه القاعدة فقط مع ال وم81 الممنوحة مباشرة للمستخدم عبر استخدام GR۸ N1‏ 
ولا تنطبق على ال و8016 المدمجة ضمن وءاهR.‏ 


:9.12 مثال تطبيقي‎ 
للمستخدم:‎ (fa )1ں‎ R01٥ لتعیین‎ 
ALTER USER Ahmad DEFAULT ROLE newusers, newusers2; 
ALTER USER Khalid,DEFAULT ROLE ALL; 
ALTER USER Omar DEFAULT ROLE ALL EXCEPT adminusers; 


ALTER USER Ali DEFAULT ROLE NONE; 


أو عبر ال ما0ئ«ه٤€:‏ 


ادخل الى ال Console‏ عڊڙر „Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷584‏ عوضاً عن إوصإ٥..‏ 

.Security Manager J| + اضغخط على‎ 

اضغط على + بجانب المجلد ءإعول › ثم اختر اسم ال مول المراد تعديله. 

في النافذة اليمنى › اختر قائمة 016 ۸› ثم ضع علامة صح اسفل ال ٤اu؟‏ وع( لل م1٠8‏ الذي تريده 
أن یکون {[uںه50ef.‏ 

.۸ اضغط على راصم‎ ٠ 
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:ENABLING AND DISABLING ROLES 
لا يستطيع المستخدم‎ .SE۲ R0٥۴ یمکن تحویل حالة ال مه8 بین 1ا2ہ و ٥[ط ھی( باستخدام جملة‎ 
عندما تكون في حالة م[ط ء1( › ويجب تحويل حالتها الى ٥1[ط ھم لأستخدام ال‎ 801١ استخدام ال‎ 
فقط على ال رمذوومS ولا تكون التغييرات دائمة › إنما تعود ال‎ 3٤۲ ۸O۴ داخلها. تؤثر ال‎ Privileges 
كلمة سر لتحويل‎ R1١ لوضعها الطبيعي بعد خروج المستخدم من ال مودطو٤د5. عندما يتطلب ال‎ ۴6 
وإن کان‎ D٥ ؟ںو[٤‎ R٥1٥ ولا ینطبق الحال علی ال‎ › SE R01٤ حالته » يحب كتابة كلمة السر في جملة‎ 
من ضمنه 814 تتطلب كلة سر لأن ال 1۲هR ٤1ں؟ وء يتم تحويلها الى حالة ٠1ط" بشكل أوتوماتيكي.‎ 
يمكن تحويل حالة ال م1٠8 باستخدام القاعدة التالية:‎ 
SET ROLE 
1 role_name [IDENTIFIED BY PASSWORD] [, role name ....] 


| ALL [EXCEPT [role name, role _ name.,...] 
[NONE } 


:9.13 مثال تطبيقي‎ 
:Enab1e الى‎ 801e لتحويل حالة ال‎ 
SET ROLE newusers, depaftA_users; 
SET ROLE newusers2 IDENRIFIED BY nGiut300; ّ 
:adminusersJl#ûÙغ‎ Enable اذى‎ 801s لتحويل حالة جميع ال‎ 

SET ROLE ALL EXCEPT adminusers; 
:5iءهطام لتحويل حالة جميع ال و8016 الى‎ 


SET ROLE NONE; 


:REMOVING ROLES FROM USERS 
يمكن إلغاء ال ومإهR من ال ومول باستخدام القاعدة التالية:‎ 


REVOKE role name , role name, ... 
FROM { role_name | PUBLIC} , {role name | PUBLIC} ,..; 


:الءe۶ لإلغاء ال e[مR من ال‎ 
REVOKE newusers FROM Khaled; 


أو عبر ال مامء”ه٤:‏ ذات الطريقة المستخدمة في إلغاء ومعم ]۴:۷1 من ال ومءا. 
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:DROPPING ROLES 


يمكن حذف ال وم1هR‏ من ال مودطهه 0 وبالتالي من ال ومول باستخدام القاعدة التالية: 


DROP ROLE role name ; 


ملاحظة: يحتاج المستخدم اى PROP ANY ROLE privilege‏ لحذف أي R01‏ في ال seھطھ†0D4.‏ 


مثال تطبيقي 9.15: 


لحذف ال R01٥‏ من ال ¢4sطData:‏ 


DROP ROLE newusers2; 


أو باستخدام ال 0[eی,ه°٤:‏ 


ادخل الى ال Console‏ عڊڙر .Standalone‏ 

اضغط على اسم Database Û‏ لکي تظهر نافذة تطلب من اسم المستخدم وكلمة السر. 

أدخل اسم المستخدم وكلمة السر مع التاكد من اختيار S۷¥5S584‏ عوضاً عن إومإه.. 

.Security Manager J| + اضغط على‎ 

اضغط على + ال 8٠1٥١‏ واخترهاسم(ال 8٠1٥‏ المراد حذفه ثم بواسطة الزر اليمين للفأرة أختر من 
القائمة “R٠0۷”‏ (يمكن استخداام قائمة ٤ءء‏ زط0 ثم ۸٤” 0٠۷٠‏ عوضاً عن الزر اليميين 
للفأرة). 

اختر و۷6. 


:QUERYING INFORMATION 


للحصول على معلومات حول ال وماهR:‏ 


.04اهطووe توفر معلومات حول جمیع ال 8014 الموجودة في ال‎ :D(8BA_ ROS 


PRS‏ _LEا8۸_R۴O(:‏ توفر معلومات حول ال و16٥8‏ الممنوحة للمستخدمين أو المدمجة مع 
آاخری. 


:۴0LE_ROLE_PRIVS‏ توفر معلومات حول ال وم801 المدمجة مع وم801 أخرى. 


:D(8BA_SYS_PR۷8‏ توفر معلومات حول ال ومعم‌۷1آا۴ ءاور الممنوحة للمستخدمين أو 
لل .R0[6s‏ 


:ROLE_SYS_PRIVS‏ توفر معلومات حول ال sەعم]¡۲¡v System‏ الممنوحة لل و6[م۸. 
:ROLE_ A B_PRIVS‏ توفر معلومات حول ال sەgم]¡v¡‏ ا۴ زط0 الممنوحة لل وم[هR.‏ 


:SESS1[0N_ROLES‏ توفر معلومات حول ال E4104 ® 016s‏ للمستخدم الحالي. 
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اذمل العاشر 


الدعم العالمي 


GLOBALIZATION SUPPORT 


GLOBALIZATION SUPPORT 


المقصود بال ٤ا0‏ ممu؟‏ «هنا)ونادطما › إمكانية استخدام لغات عالمية وتقويمات عالمية في الأوراكل. 


من المميزات التي يوفرھا :Globalization Support J|‏ 


إمكانية حفظ واستخراج البيانات باللغة المحلية. 

إمكانية تشغيل ال وع1)اذ) ا مء4طه)ه باللغة المحلية. 

إمكانية عرض ال ومعھءوم]۷ ٣٣٠۲‏ باللغة المحلية. 

أمكانية استخدام بعض التقويمات المحلية مثل التقويم الياباني. 

إمكانية عرض الأرقام باللغة المحلية. 

إمكانية استخدام رموز العملات العالمية. 

إمكانية استخدام فارق التقويم الزمني بين الدول. 

إمكانية استخدام مجموعة من النظم لتعريف lأغlٽت"es .Unicode Jia "Encoding Sch e‏ 
التحويل الأوتوماتيكي بين اللغات» أي استخدام المستخدم ٣11٠٤‏ لغة مختلفة عن لغة السيرفر. 


:ENCODING SCHEMES 


يوفر الأوراكل مجموعة من النظم لتعريف اللتغات منها: 


BYTE-LEاS[NG:‏ یتم استخدام بایت واحد,لتخزین حرف واحد. یوجد نوعان هما )زا-7 (مثال 
.{WESDEC Jlûn) 8-bit s (US7ASCII‏ 


AR Y1NG-WD 1۸‏ ۷: يمكن تخزين الحرف الواخفي أكثر من بايت وتستخدم هذه الطريقة 
غالباً في اللغات الأسيوية مثل الصينية واليابانية (مثال 3٤€‏ و 1۴8 7ا۸132). 


.)۸ 1161۲۴16 یتم تحدید عدد محدد من البایتات' لکل حرف (مثال‎ :۴1XED-WIDTH 
نظام معتمد في جميع أنحاء العالم لقدرته على تعريف جميع اللغات والرموز الخاصة‎ : UN] 0٤ 


والرموز المستخدمة في النشر (مثل © ®). يمكن أن تتكون ال ٠0ء‏ 1م من مجموعة من النظم 
المختلفة .(UTF-16 Jlûa) Fixed-Widths (UTF-8 Jlûa) Varying-Width Jû‏ 


:CHOOSING CHARACTER SET 


خلال دراستنا لقاعدة CREATE DATABASE‏ › تعرفنا الى جم CHARACTER SET‏ التي تحدد 
نوعية النظام الخاص باللغة" )ع إماءوإوط٤"‏ الذي سوف يستخدم في ال مووطه)ه0 (مثل 
.)۸A8‏ یستخدم نظام ال Character set‏ لتخزین اسمlء Data gy Columns Jly Tables J|‏ 
في „a Character Set JJ Default J| ãميقll .CHAR, VARCHAR2, LONG, CLOB iı‏ 
استخدام 8011 187۸[. لا یمکن تغییر ال C14۲4) Se)‏ بعد تکوین ال 6ء4طھtھ(‏ عدا في بعض 
الأستثنائات القليلة (مثلاً عندما يكون ال S6٤‏ إماء دإ هط الجديد مطابق بشكل كبير للنوع القديم). 

عملية انتقاء ال ٤ء‏ )اط المناسب تعتمد على الأحتياجات الحالية والمستقبلية معاًء أي في حالة 
وجود احتمال استخدام لغات عديدة في المستقبل» يفضل استخدام Character Set‏ قادر على استیعاب لغات 


عدة. 
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أيضاً يجب الأخذ بالإعتبار نوعية ال S٤‏ إم)ءوإهط المتوفرة في نظام التشغيل " ڇہ1)و١ء0p‏ 
"System‏ اذ أن الإختلاف بين النظاميين يؤدي الى عملية تحويل يقوم بهل الأوراكل مما قي يؤدي الى حدوث 
عبئ وضغط من جراء عملية التحويل › مما قد يؤدي الى ضياع بيانات. 

يعتبر استخدام ٠)ر8-ء1ع‏ ,$1 أفضل من الناحية الفنية والأداء عن استخدام 1)1 W-ع"1ر‏ اه۷ ولكن 
إمكانيات ال م٤‏ ر8-ء[عمذ؟ في تعدد اللغات محدودة جدا. 


.Character Set JÛ مlظis‎ Fixed-Width pدختسا ملاحظة: لا يمكن‎ 


:CHOOSING NATIONAL CHARACTER SET 


NATIONAL CHARACTER SET ya CREATE DATABASE ةدعlق يوجد نوع إضافي في‎ 
Default J| ةnıقll‎ .NCHAR, NVARCHAR2, NCLO8B الذي يستخدم لتخزين البيانات في هين‎ 
National Character JÛ يمکن استخدام قیمتان‎ .A۴16U F16 هي‎ National Character Se Jİ 
بعد‎ National Character Set J| ريıغت‎ jay J .UTF-8§ و‎ UTF-16 Unicode Jl فقط هما قيمتا‎ 
تكوين ال مووطه)د( عدا في بعض الأستثنائات القليلة.‎ 

عملية انتقاء ال Nationa1 Character S6٤‏ تعتمد على اللغة المراد استخدامها › ففي حالة اللغات 
الأوروبية يتم حجز بين ٠٤ر8‏ 1 الى م)ر8 2 لكل حرف (أي أن الأحرف لا تحجز مساحة ثابتة بل متغيرة) › 
ولذلك یفضل استخدام 11۴-8 لأنھا من نوع متغیر 2-W 1٤1‏ ,را۷ (من 1 بایت الى بایت 3)ء ولکن 
تعتبر ال 01۴-16 أسرع وأقل عبئ فيال #ووط وغه لأنها من النوع الثابت .F۴ixed-W id‏ 


:USING NLS PARAMETERS 


يوفر الأوراكل مجموعة من العوامل يطلق عليها اسم National Language Supضمص0!غ (NS)‏ تساعد 
على تحديد أمور مختلفة عالمياً مثل طريقة حفظ وعرض التايخ.والتوقيت» الرمز المستخدم للعملة المحليةء 
اليوم الأول في الأسبوع (السبت عند المسلمين والاثنين عند الغري) وغيرها من الأمور. 


يمکن تحدید عوامل ال N18‏ بثلاث طرق هي: 


.Initialization Parameter File JI Jıدعت عبر‎ 
)Rهعایtار یستخدم في نظام الویندوز ال‎ ( Environment Vara b1es باستخدام ال‎ 
.ALTER SESSION J ûلمج باستخدام‎ 


التعديل بواسطة جملة ۸L۲ ER SESS10۸‏ ھو الأقوی ثم یلیھ استخدام Environment JI‏ 
aris‏ . هذا يعني اذا تم تعدیل أحد العوامل بواسطة ال Par 4me) ۴1e‏ izationاnitia]‏ وبواسطة 
جملة ER SESSION Û‏ "1 » فإن قيمة العامل تكون هي المحددة بجمل ALTER SESSION J‏ 
وليس القيمة المحددة بJl Parameter File‏ izationاnitia!‏ أو القيمة المحددڈ بJl Environment‏ 
.Variables‏ 


ملاحظة: بعض العوامل لا تتغير بواسطة Environment ÛJ مlدختwlڊ gi ALTER SESSION‏ 


. Variables 


تذکر: جاء ذکر ال Environment Vھrنھط [6s‏ في الفصل الثالث. 
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:NLS Parameters 
يوفر الأوراكل عدد من العوامل منها:‎ 


° 1S_LANGUAGEاN:‏ يستخدم في عرض اسماء الأيام والشهور» ويستخدم لعرض الرموز 
الخاصة بالتوقيت والتاريخ مثل قبل أو بعد الميلاد ( 8٣‏ ,5 ۸) أو التوقیت (۸[۷1 )۶M,‏ › ویستخدم 
كلغة الرسائل المعروضة في الأوراكل مثل رسائل الأخطاء "عع ھیوم۷1 "٤۲۲٥۲‏ › ويستخدم ايضاً 
في تحديد نوعية عملية .Sorting ÛJI‏ 


› يستخدم في تحديد طريقة عرض التاريخ » واختيار رمز للعملة المحلية‎ :Nا1S_"‎ ERR" RY 
.190 تحديد أول يوم في الأسبوع وتحديد قيم تعرف باسم قيم ال‎ 


.NLS_LANG ° 


تشمل ا NLS LANGUAGE‏ قیم ال u1‏ هfەD‏ للعوامل التالية: 


:N1S_ DAE_ LANGUAGE‏ لتحديد اسماء الشهور والأيام والإختصارات المعمول بها (مثل 
اختصار يوم الإثنين بالغة الإنجليزية .(MON‏ 

٠‏ ١S_S0RاN:‏ لتغيير طريقة تزتيب البيانات "ع«ذ٤إه5S"‏ في الأوراكل › مثلاً اذا تم تحدید قيمتها 
بالتاڵي NHS=SORT =6Ger ı41‏ فان ترتيب البيانات سوف يكون طبقاً للأبجدية الألمانية. 


أما ال N18 "ERR ORY‏ فتشمل قيم 10ں وء( للعوامل التالية: 


1S_CURRENCYاN:‏ لإختيار رمز للعملة المحلية. 

:N1.8_1S0_)RRENCY‏ لإختيار رمز مخيّطر لعلية البلد مثل 105 للدولار الأمريكي. 
:N1.8_D A E_FORMAT‏ لتحديد طريقة عرص التاريخ» مثلاً الأيام ثم الشهور ثم السنين. 
15_NUMERIC_CHARACTERSاN:‏ لتحديد طريقة عرض الأرقام التي تحوي على 
فواصل مثل الأرقام الغير صحيحة (مثل 222.44.5). 


المقصود بأن العامل N19_1 ۸ ۸1۲0 R۷‏ يشمل القيم ال )وء( للعوامل الأخرى › بذلك هو عند 
تحدید قيمة ال ۸1۲0۸۷ N1.5S_1 E۸‏ » فليس من الضروري تحديد قيم العوامل التي يشملها. 

أيضاً في حالة تحديد العامل N11 1٤۸۸1۲0۸۷‏ والعوامل التي يشملها › يتم تغيير قيم العوامل التي 
يشملھا« حيث أن تغيير قيمة إلعاJa NLS TERRITORY‏ يتم فقط في Environment Variaۆb]es Û|‏ 
أو عبر جملة ال ٤R S٤SS10 ٩‏ 1 مما يجعله النوع الأقوى من العوامل التي يشملها التي تتغير 

جميع الطرق. مثال على ذلك اذا تم تحديد قيمة العامل N1.9_)0€ ۸R ٤N ٣¥‏ بالقيمة £ (الباوند) في ال 
Parameter File‏ iationاnifia]‏ ولكن ايضاً تم تحديد قيمة العملة المحلية في 

N18" ERRITORY‏ بالقيمة ¥ (الين الياباني) فإن رمز العملية المحلية في الأوراكل يكون الين الياباني. 


:NLS_LANG Parameter 
ویتم تحدیدھا فقط عبر استخدام ال‎ N18_].۸ N6 يمكن استخدام قيم مختلفة لکل مستخدم باستخدام ال‎ 
Character s Territory s Language تتكون من ثلاث اقpl ھي‎ .Environment Variables 


Se)‏ معرفة بالقاعدة التالية: 


NLS_LANG = Langugae_Territory.Charset 
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في القاعدةء 


guage‏ anا:‏ هي موازية للعامل N18 LANGUAGE‏ ویتم تعریف قیمتها في الأوراکل عند 
تحدید ها ولا یتم الأخذ بقیمة N1 S_ L۸ N6 [۸6٤‏ › اذ یعتبر العامل NG‏ 19_1۸ ھو الأقوی 
في الأوراكل. 

:rerritory‏ هي موازية للعامل N1S_ ٤R R1۲0‏ ويتم تعريف قيمتها في الأوراكل عند 
تحدید ها ولا یتم الأخذ بقيمة ٤R R170 RY‏ S|اN‏ »اذ يعتبر العامل NS 1۸ NG‏ هو 
الأقوى في الأوراكل. 

:€Charse)‏ يحدد نوعیة ال Character Se)‏ للمستخدم فقط, 


:NLS and Functions 


خلال دراستك للإمتحان الأول "1ntrodu ction )٥ SQ"‏ استخدمت ال NS Parameters‏ داخل 
عمليات متعددة مثل جملة ٠ 10_€C81۸R‏ وللتذكير راجع المثال 10.1. 


مثال تطبيقي 10.1: 


SELECT TO_CHAR (hire date, $DD.Mon.YYYY’, 
‘NLS DATE LANGUAGE = GERMAN’) 
FROM HR.EMPLOYEES 


يمكن استخدام العوامل التالية مغ ۸۴ :10_€C#BH‏ 


NLS_DATE_LANGUAGE 
NLS_NUMERIC_CHARACTERS 
NLS_CURRENCY 
NLS_ISO_CURRENCY 
NLS_CALENDAR 


يمكن استخدام العوامل التالية مع ۲0_(0۸1۴: 
NLS_DATE_LANGUAGE‏ 
NLS_CALENDAR °‏ 
يمكن استخدام العوامل التالية :TO_NUMBER ga‏ 
NLS_NUMERIC CHARACTERS °‏ 


NLS_ CURRENCY 
NLS_ISO_CURRENCY ° 
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:QUERYING INFORMATION 
:NاS للحصول على معلومات حول ال‎ 


JI Character Set J| jع تر زومت‎ :NLS_DATABASE_PARAMETER ® 
طھغ04.‎ 44e المستخدم في ال‎ Nationa1 Character Set 


SELECT PARAMETER, VALUE 


FROM NLS_DATABASE_PARAMETER 
WHERE PARAMETER LIKE ‘%¢CHARACTERSET%’; 


:N18_1NSTANCE_PARAMETER‏ توفر معلومات عن قيم عوامل ال N18‏ المحددة في 
.Initialization Parameter File Û!‏ 


° 1S_SESSI[ON_PARAMETERاN:‏ توفر معلومات عن قيم عوامل ال N15‏ المحددة لل 
Session‏ فقط, 


1D_VALUESاS_V۷AاŞN$:‏ توفر معلومات حول جميع القيم المتوفرة المسموح استخدامها 
لتحديد .Language, Territory, Character Set JI ùم J‏ 
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